日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
SQL Server游標(biāo)生成工具
 
 
 
 
  1. Declare @Age int 
  2. Declare @Name varchar(20) 
  3. Declare Cur Cursor For Select Age,Name From T_User    
  4. Open Cur 
  5. Fetch next From Cur Into @Age,@Name 
  6. While @@fetch_status=0      
  7. Begin 
  8.    Update T_User Set [Name]=@Name,Age=@Age 
  9.    Fetch Next From Cur Into @Age,@Name 
  10. End    
  11. Close Cur    
  12. Deallocate Cur 

在實際應(yīng)用時,經(jīng)常需要找到這個模板,然后再根據(jù)實際的表結(jié)果,重寫一遍。經(jīng)常遇到以下二個問題

成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的襄州網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

1  上面的例子腳本不知道放在哪里了,或是有很多例子腳本,不方便很快找出來

2  重寫游標(biāo)的例子,經(jīng)常重復(fù),又沒有技術(shù)難度可言。比如讀取工作單生產(chǎn)計劃,讀取用戶。

經(jīng)過思考,于是寫個游標(biāo)生成工具,把上面的模板代碼,應(yīng)用到代碼生成器中。

注意上圖中的Script Cursor,這是用來生成游標(biāo)模板的。選擇一個數(shù)據(jù)庫,樹左邊選擇表名,勾選字段值,點擊執(zhí)行

 
 
 
 
  1. DECLARE  @UserID  NVARCHAR(10)  
  2.  DECLARE  @UserName  NVARCHAR(50)  
  3.  DECLARE  Cur  CURSOR  FOR  SELECT  [UserID],[UserName]  FROM  [USER]    
  4.  OPEN  Cur  
  5.  FETCH  next  FROM  Cur  INTO  @UserID,@UserName    
  6.  WHILE  @@fetch_status=0          
  7.  BEGIN  
  8.      FETCH  next  FROM  Cur  INTO  @UserID,@UserName    
  9.  END        
  10.  CLOSE  Cur        
  11.  DEALLOCATE  Cur  

源代碼不到50行,全文如下

 
 
 
 
  1.  List  fieldlist = this.GetFieldlist(); 
  2.  StringBuilder builder=new StringBuilder(); 
  3.  string typeName = string.Empty; 
  4.             
  5.  foreach (ColumnInfo columnInfo in fieldlist) 
  6.     { 
  7.                 switch (columnInfo.TypeName) 
  8.                 { 
  9.                     case "datetime": 
  10.                     case "int": 
  11.                     case "image": 
  12.                     case "bit": 
  13.                         typeName = columnInfo.TypeName; 
  14.                         break; 
  15.                     case "nvarchar": 
  16.                     case "nchar": 
  17.                     case "varchar": 
  18.                     case "char": 
  19.                         typeName =string.Format("{0}({1})", columnInfo.TypeName,columnInfo.Length); 
  20.                         break; 
  21.                 } 
  22.                 builder.AppendLine(string.Format("Declare @{0} {1}", columnInfo.ColumnName, typeName)); 
  23.   } 
  24. var columns = string.Join(",", (from column in fieldlist 
  25.                                             select "["+column.ColumnName+"]").ToArray()); 
  26.  
  27. string fetchNex= string.Join(",", (from column in fieldlist 
  28.                                             select "@"+column.ColumnName).ToArray()); 
  29.  
  30. string update= string.Join(",", (from column in fieldlist 
  31.                                               select "@"+column.ColumnName+"=["+ column.ColumnName+"]").ToArray()); 
  32.  
  33. builder.AppendLine(string.Format("Declare Cur Cursor For Select {0} From [{1}] ", columns, this.tablename)); 
  34. builder.AppendLine("Open Cur"); 
  35.  builder.AppendLine(string.Format("Fetch next From Cur Into {0} ", fetchNex)); 
  36.  builder.AppendLine("While @@fetch_status=0    "); 
  37.  builder.AppendLine("Begin"); 
  38.              
  39. //builder.AppendLine(string.Format("  Update [{0}] Set {1} ",this.tablename,update)); 
  40. builder.AppendLine(string.Format("  Fetch next From Cur Into {0} ", fetchNex)); 
  41.  
  42. builder.AppendLine("End   "); 
  43. builder.AppendLine("Close Cur   "); 
  44. builder.AppendLine("Deallocate Cur"); 

有以下幾點需要注意

1  生成的腳本中,字段名稱,表名稱,均要加上方括號,以避免名稱重突。

2  最后生成的SQL源代碼,還需要應(yīng)用下面的方法,將SQL關(guān)鍵字大寫。

將SQL查詢語句的關(guān)鍵字大寫的方法來自CSDN下載區(qū),全文如下

 
 
 
 
  1. private static Regex RegexSQLCapitalize = new Regex("\\badd\\b|\\baggregate\\b|\\baction\\b|\\balter\\b|\\bas\\b|\\basc\\b|\\basymmetric\\b|\\bauthorization\\b|\\bbegin\\b|\\bbinary\\b|\\bbit\\b|\\bby\\b|\\bcascade\\b|\\bcase\\b|\\bcatalog\\b|\\bcharacter\\b|\\bchar\\b|\\bcheck\\b|\\bcheckpoint\\b|\\bclose\\b|\\bclustered\\b|\\bconstraint\\b|\\bcollate\\b|\\bcolumn\\b|\\bcommit\\b|\\bcontains\\b|\\bcontinue\\b|\\bcreate\\b|\\bcross\\b|\\bcursor\\b|\\bdatabase\\b|\\bdeallocate\\b|\\bdesc\\b|\\bdecimal\\b|\\bdeclare\\b|\\bdefault\\b|\\bdelete\\b|\\bdesc\\b|\\bdistinct\\b|\\bdouble\\b|\\bdrop\\b|\\belse\\b|\\bend\\b|\\bescape\\b|\\bexcept\\b|\\bexec\\b|\\bexecute\\b|\\bexternal\\b|\\bfetch\\b|\\bfloat\\b|\\bforeign\\b|\\bfor\\b|\\bfrom\\b|\\bfunction\\b|\\bget\\b|\\bgroup\\b|\\bgoto\\b|\\bgrant\\b|\\bhaving\\b|\\bidentity\\b|\\binto\\b|\\bindex\\b|\\binsert\\b|\\binstead\\b|\\bint\\b|\\bkey\\b|\\bname\\b|\\bof\\b|\\bon\\b|\\bopen\\b|\\boption\\b|\\border\\b|\\boutput\\b|\\bprimary\\b|\\breturn\\b|\\brollback\\b|\\bschema\\b|\\bselect\\b|\\bsize\\b|\\bsymmetric\\b|\\bset\\b|\\bserver\\b|(\\btable\\b)|\\bthen\\b|\\btop\\b|\\btime\\b|\\btimestamp\\b|\\bto\\b|\\btrigger\\b|\\bprocedure\\b|\\btype\\b|\\bunion\\b|\\bunique\\b|\\bupdate\\b|\\buse\\b|\\bvalues\\b|\\bvalue\\b|\\bvarchar\\b|\\bview\\b|\\bwhen\\b|\\bwhile\\b|\\bwhere\\b|\\bwith\\b|\\bnvarchar\\b|\\bnchar\\b|\\bdatetime\\b|\\bfloat\\b|\\bdate\\b|\\bdatediff\\b|\\bdateadd\\b|\\bdatename\\b|\\bdatepart\\b|getdate|\\breferences\\b|\\babs\\b|\\bavg\\b|\\bcast\\b|\\bconvert\\b|\\bcount\\b|\\bday\\b|\\bisnull\\b|\\blen\\b|\\bmax\\b|\\bmin\\b|\\bmonth\\b|\\byear\\b|\\breplace\\b|\\bsubstring\\b|\\bsum\\b|\\bupper\\b|\\buser\\b|\\ball\\b|\\bany\\b|\\band\\b|\\bbetween\\b|\\bexists\\b|\\bin\\b|\\binner\\b|\\bis\\b|\\bjoin\\b|\\bleft\\b|\\blike\\b|\\bnot\\b|\\bnull\\b|\\bor\\b|\\bright\\b|\\btry\\b|\\bcatch\\b", RegexOptions.IgnoreCase); 
  2.  
  3. public static string CapitalizeSQLClause(string source) 
  4.  
  5.            //先按行劃分 
  6.            Regex rowReg = new Regex("\r\n"); 
  7.            string[] strRows = rowReg.Split(source); 
  8.  
  9.            StringBuilder strBuilder = new StringBuilder(); 
  10.            int rowsCount = strRows.Length; 
  11.  
  12.            for (int i = 0; i < rowsCount; i++) 
  13.            { 
  14.                //去掉一行中的一個或多個空白 
  15.                //strRows[i] = Regex.Replace(strRows[i], @"\s+", " "); 
  16.  
  17.                //按空格劃分 
  18.                string[] strWords = strRows[i].Split(new char['\0']); 
  19.                int wordsCount = strWords.Length; 
  20.  
  21.                for (int j = 0; j < wordsCount; j++) 
  22.                { 
  23.                    strBuilder.Append(" "); 
  24.                    if (RegexSQLCapitalize.IsMatch(strWords[j])) 
  25.                    { 
  26.  
  27.                        MatchCollection mc = RegexSQLCapitalize.Matches(strWords[j]); 
  28.                        int mcmcCount = mc.Count; 
  29.                        for (int k = 0; k < mcCount; k++) 
  30.                        { 
  31.                            strWords[j] = strWords[j].Replace(mc[k].Value, mc[k].Value.ToUpper()); 
  32.                        } 
  33.                        strBuilder.Append(strWords[j]); 
  34.                    } 
  35.                    else 
  36.                    { 
  37.                        strBuilder.Append(strWords[j]); 
  38.                    } 
  39.                    strBuilder.Append(" "); 
  40.                } 
  41.  
  42.                strBuilder.Append("\r\n"); 
  43.            } 
  44.            return strBuilder.ToString().Replace("\r\n\r\n", "\r\n"); 

正則表達式替換字符串中的關(guān)鍵字,這個方法沒有任何依賴,可拷貝到您的項目或類庫中,為SQL 腳本增加關(guān)鍵字大寫功能。

3  SQL 腳本格式化功能  如果能把生成的SQL腳本格式化一下,生成美觀的SQL腳本,增加可讀性。SQL Pretty Printer可以做到,但是沒有找到API可以調(diào)用這個功能。

4 多表關(guān)聯(lián)的游標(biāo)模板沒有做到。應(yīng)該嘗試從多個關(guān)聯(lián)表中生成游標(biāo)。不過表與表之間的關(guān)系難以自動生成,比如像下面的母子表游標(biāo)詢語句

 
 
 
 
  1. Declare Cur Cursor For Select r.Description,r.WorkCenter  FROM JobOrder  j, JobOrderRouting r 
  2.      WHERE j.JobNo=r.JobNo 
  3. Open Cur 

游標(biāo)要從2個關(guān)聯(lián)的表中讀取數(shù)據(jù),如果2個表之間有外鍵關(guān)聯(lián),可以生成2個表的外鍵關(guān)聯(lián)字段的關(guān)系,也就是上面的SQL游標(biāo)可以自動生成,但是有的2個表之間沒有外鍵關(guān)聯(lián)的,還是要手工指定,相當(dāng)于是個半成品的游標(biāo)生成器,于是只好把這個功能點拿掉,只做最簡單的一種情況,生成一個表的若干個字段的游標(biāo)查詢,沒有設(shè)計多表查詢的游標(biāo)。


文章名稱:SQL Server游標(biāo)生成工具
轉(zhuǎn)載來于:http://www.dlmjj.cn/article/cosjpco.html