惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 闲云

Slim通过composer生成脚本问题的解决办法 javac编译项目代码脚本片段 过滤特殊输入字符(Java) PHP的时间总结 dojo tree的折叠和展开 设置IE8和Firefox3.0的语言 Javascript中call函数 喵喵 在工作中学习 FlashForward 2006 Austin 获奖名单[转自Dengjie Blog] 无计划就不行动! 如何由已知去了解未知? 检验医学信息资源链接 如何恢复IDE默认设置 MSDN Magazine CHM &TchNet CHM下载 不常见程序写法和容易误解的概念 打印-参考例子 VS2005的正则表达式查找/替换 一句话的软件工程
利用〔正则〕检查.NET访问数据库Sql的正确性
闲云 · 2006-09-13 · via 博客园 - 闲云

背景
        利用.NET访问数据库的时候,需要写一些SQL语句。但是由于SQL的可读性、
不好测试的特点。经常会写错字母,漏写了参数等。直到写界面层的时候才发现
问题,回头再来改,十分痛苦。

想法
        利用数据库访问脚本及其数据库字段的命名约定。比如,INT类型就用INT
结尾,VARCHAR就用VCHR结尾等。有了这些,我们就可以根据约定自动生成
相关类型的数据了。下面就是利用程序生成的例子!

UPDATE TABLE
SET 
COLUMNNAME1_VCHR 
= ?,
COLUMNNAME2_CHR 
= ?,
COLUMNNAME3_VCHR 
= ?
WHERE COLUMNNAME4_INT = ?
===   CONVERT TO == >>>
UPDATE TABLE 
SET 
COLUMNNAME1_VCHR
='aaaa',
COLUMNNAME2_CHR
='aaaa',
COLUMNNAME3_VCHR
='aaaa' 
WHERE COLUMNNAME4_INT=17;

然后这些脚本就可以在SQLNavigat中运行了,以判断字段的正确与否。

正则表达式
         利用正则表达式匹配、捕抓一些我们需要的特定格式的数据非常的方便。比
如,捕抓 "ColumnName=?"  "INSERT ..." "SELECT ..."  "(?,?,?,?)"  等。这样我们就可
以快速的捕抓出这些数据,然后根据命名约定进行数据替换。
         几个正则Pattern(不是太严谨),有关正则的学习,可以参照我Blog中的资源
几个模式:
     匹配    "INSERT ..." "SELECT ..." "DELETE..." "UPDATE ..."    
                "\s*(INSERT|DELETE|SELECT|UPDATE) ((?!\" ).)*"     匹配    " VAR = ?" "VAR<?" "VAR>?" "VAR>=?"
                 \w*\s*  ( \= | \> | \>\= | \<\= | \!\= )   \s*\?
     匹配    "(?, ?, ?, ?)"
                 \( ((?!\().)*\)
    
程序片断

根据约定生成测试值


private string GenerateRadomValue(string columnName)
        
{
            
string strRadom = string.Empty;
            
if (columnName.Contains("INT"))
            
{
                Random ran 
= new Random();
                strRadom 
= ran.Next(100).ToString();
            }

            
else if (columnName.Contains("CHR"|| columnName.Contains("VCHR"))
            
{
                strRadom 
= "'aaaa'"// 自己定义
            }

            
else if (columnName.Contains("DAT"|| columnName.Contains("DT")) 
            
{
                strRadom 
= "to_date('2005-11-25 00:00:00', 'yyyy-MM-dd hh24:mi:ss')";
            }

            
return strRadom;
        }

程序下载
        源程序 下载