隨筆:2 文章:1 評(píng)論:1 引用:0
          BlogJava 首頁 發(fā)新隨筆
          發(fā)新文章 聯(lián)系 聚合管理

          2009年4月29日

          新一篇: 利用WatiN自動(dòng)化網(wǎng)站功能測(cè)試 | 舊一篇: 代碼自動(dòng)生成工具M(jìn)yGeneration之三
          前面學(xué)過了基本的存儲(chǔ)過程,見

          存儲(chǔ)過程入門

          現(xiàn)在學(xué)一下常用的存儲(chǔ)過程的語法,只要花一點(diǎn)點(diǎn)時(shí)間學(xué)習(xí)下,就能用存儲(chǔ)過程實(shí)現(xiàn)很復(fù)雜的功能,可以少寫很多代碼。

          為了方便說明,數(shù)據(jù)庫使用SQL Server的示例數(shù)據(jù)庫,Northwind和pubs,如果SQL Server中沒有的話,可以按下面的方法安裝

          1,下載SQL2000SampleDb.msi,下載地址是:
          http://www.microsoft.com/downloads/details.aspx?FamilyId=06616212-0356-46A0-8DA2-EEBC53A68034&displaylang=en
          2,安裝后,到默認(rèn)目錄C:\SQL Server 2000 Sample Databases 有instnwnd.sql ,instpubs.sql兩個(gè)文件
          3,在sql server中運(yùn)行這兩個(gè)sql 就可以創(chuàng)建你Northwind和pubs數(shù)據(jù)庫。

          下面開始學(xué)T-SQL的語法


          一.注釋


          -- 單行注釋,從這到本行結(jié)束為注釋,類似C++,c#中//
          /* … */ 多行注釋,類似C++,C#中/* … */


          二.變量(int, smallint, tinyint, decimal,float,real, money ,smallmoney, text ,image, char, varchar。。。。。。)
          語法:
          DECLARE
          {
          {@local_variable data_type}
          } [,...n]
          例如:


          declare @ID int --申明一個(gè)名為@ID的變量,類型為int型

          三.在SQL Server窗口中打印出變量的值


          語法:
          PRINT 'any ASCII text' | @local_variable | @@FUNCTION | string_expr


          四.變量賦值


          例如:

          --從數(shù)據(jù)表中取出第一行數(shù)據(jù)的ID,賦值給變量@id,然后打印出來
          Declare @ID int
          Set @ID = (select top(1) categoryID from categories)
          Print @ID

          在SQL中,我們不能像代碼那樣直接給變量賦值,例如@id = 1,如果要達(dá)到這樣的功能,可以這樣寫:

          Declare @ID int
          Set @ID = (select 1) -- 類似 @ID=1
          Select @id=1 -- 類似 @ID=1
          Print @ID


          五.變量運(yùn)算(+,-,*,/,……)


          以下必要時(shí)候省略變量申明
          Set @ID = (select 1+5) --類似 @ID=1+5
          Set @ID=(select 1-@ID) --類似 @ID=1-@ID

          六.比較操作符
          • > (greater than).
          • < (less than).
          • = (equals).
          • <= (less than or equal to).
          • >= (greater than or equal to).
          • != (not equal to).
          • <> (not equal to).
          • ! < (not less than).
          • !> (not greater than).
          沒什么說的


          七.語句塊:Begin … end
          將多條語句作為一個(gè)塊,類似與C++,C#中的{ }
          例如:
          Begin
          Set @ID1 = (select 1)
          Set @ID2 = (select 2)
          End

          八.If, if…else…
          語法:
          IF Boolean_expression
          {sql_statement | statement_block}
          [ELSE
          {sql_statement | statement_block}]
          例如:

          If @id is not null
          Print ‘@id is not null
          if @ID = 1
          begin
          Set @ID = (select 1 + 1)
          end
          else
          begin
          set @ID=(select 1+2)
          end


          上面的例子用到了比較操作符,語句塊,和IF的語法。


          九.執(zhí)行其他存儲(chǔ)過程 EXEC
          例如

          EXEC dbo.[Sales by Year] @Beginning_Date=’1/01/90’, @Ending_Date=’1/01/08’


          十.事務(wù)

          語法:


          BEGIN TRAN[SACTION] [transaction_name | @tran_name_variable]


          例如

          BEGIN TRAN
          -- 做某些操作,例如Insert into …
          if @@error <> 0
          BEGIN
          ROLLBACK TRAN
          END
          else
          BEGIN
          COMMIT TRAN
          END

          十一.游標(biāo)

          我們可以在存儲(chǔ)過程中用Select語句取出每一行數(shù)據(jù)進(jìn)行操作,這就需要用到游標(biāo)。


          語法:
          DECLARE cursor_name CURSOR
          [LOCAL | GLOBAL]
          [FORWARD_ONLY | SCROLL]
          [STATIC | KEYSET | DYNAMIC | FAST_FORWARD]
          [READ_ONLY | SCROLL_LOCKS | OPTIMISTIC]
          [TYPE_WARNING]
          FOR select_statement

          [FOR UPDATE [OF column_name [,...n]]]


          例如:

          DECLARE @au_id varchar(11), @au_fname varchar(20) –申明變量
          --申明一個(gè)游標(biāo)
          DECLARE authors_cursor CURSOR FOR
          SELECT au_id, au_fname FROM authors
          --打開游標(biāo)
          OPEN authors_cursor
          --取出值
          FETCH NEXT FROM authors_cursor INTO @au_id, @au_fname
          --循環(huán)取出游標(biāo)的值
          WHILE @@FETCH_STATUS = 0
          BEGIN
          Print @au_id
          Print @au_fname
          Print ‘ ’
          FETCH NEXT FROM authors_cursor
          INTO @au_id, @au_fname
          END
          CLOSE authors_cursor –關(guān)閉游標(biāo)
          DEALLOCATE authors_cursor --釋放游標(biāo)
          我覺得上面的是存儲(chǔ)過程常用的一些東東,如果要更深入的了解,更詳細(xì)的幫助,請(qǐng)參考SQL Server的幫助文檔
          posted @ 2009-04-29 11:42 付學(xué)亮 閱讀(609) | 評(píng)論 (0)編輯 收藏

          2009年4月14日

          下面都是我收集的一些比較常用的正則表達(dá)式,因?yàn)槠匠?赡茉诒韱悟?yàn)證的時(shí)候,用到的比較多。特發(fā)出來,讓各位朋友共同使用。呵呵。

          匹配中文字符的正則表達(dá)式: [u4e00-u9fa5]
          評(píng)注:匹配中文還真是個(gè)頭疼的事,有了這個(gè)表達(dá)式就好辦了

          匹配雙字節(jié)字符(包括漢字在內(nèi)):[^x00-xff]
          評(píng)注:可以用來計(jì)算字符串的長(zhǎng)度(一個(gè)雙字節(jié)字符長(zhǎng)度計(jì)2,ASCII字符計(jì)1)

          匹配空白行的正則表達(dá)式:ns*r
          評(píng)注:可以用來刪除空白行

          匹配HTML標(biāo)記的正則表達(dá)式:< (S*?)[^>]*>.*?|< .*? />
          評(píng)注:網(wǎng)上流傳的版本太糟糕,上面這個(gè)也僅僅能匹配部分,對(duì)于復(fù)雜的嵌套標(biāo)記依舊無能為力

          匹配首尾空白字符的正則表達(dá)式:^s*|s*$
          評(píng)注:可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達(dá)式

           

          匹配Email地址的正則表達(dá)式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
          評(píng)注:表單驗(yàn)證時(shí)很實(shí)用

          匹配網(wǎng)址URL的正則表達(dá)式:[a-zA-z]+://[^s]*
          評(píng)注:網(wǎng)上流傳的版本功能很有限,上面這個(gè)基本可以滿足需求

          匹配帳號(hào)是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
          評(píng)注:表單驗(yàn)證時(shí)很實(shí)用

          匹配國(guó)內(nèi)電話號(hào)碼:d{3}-d{8}|d{4}-d{7}
          評(píng)注:匹配形式如 0511-4405222 或 021-87888822

          匹配騰訊QQ號(hào):[1-9][0-9]{4,}
          評(píng)注:騰訊QQ號(hào)從10000開始

          匹配中國(guó)郵政編碼:[1-9]d{5}(?!d)
          評(píng)注:中國(guó)郵政編碼為6位數(shù)字

          匹配身份證:d{15}|d{18}
          評(píng)注:中國(guó)的身份證為15位或18位

          匹配ip地址:d+.d+.d+.d+
          評(píng)注:提取ip地址時(shí)有用

          匹配特定數(shù)字:
          ^[1-9]d*$    //匹配正整數(shù)
          ^-[1-9]d*$   //匹配負(fù)整數(shù)
          ^-?[1-9]d*$   //匹配整數(shù)
          ^[1-9]d*|0$  //匹配非負(fù)整數(shù)(正整數(shù) + 0)
          ^-[1-9]d*|0$   //匹配非正整數(shù)(負(fù)整數(shù) + 0)
          ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮點(diǎn)數(shù)
          ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配負(fù)浮點(diǎn)數(shù)
          ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮點(diǎn)數(shù)
          ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非負(fù)浮點(diǎn)數(shù)(正浮點(diǎn)數(shù) + 0)
          ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮點(diǎn)數(shù)(負(fù)浮點(diǎn)數(shù) + 0)
          評(píng)注:處理大量數(shù)據(jù)時(shí)有用,具體應(yīng)用時(shí)注意修正

          匹配特定字符串:
          ^[A-Za-z]+$  //匹配由26個(gè)英文字母組成的字符串
          ^[A-Z]+$  //匹配由26個(gè)英文字母的大寫組成的字符串
          ^[a-z]+$  //匹配由26個(gè)英文字母的小寫組成的字符串
          ^[A-Za-z0-9]+$  //匹配由數(shù)字和26個(gè)英文字母組成的字符串
          ^w+$  //匹配由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串

          在使用RegularExpressionValidator驗(yàn)證控件時(shí)的驗(yàn)證功能及其驗(yàn)證表達(dá)式介紹如下:

          只能輸入數(shù)字:“^[0-9]*$”
          只能輸入n位的數(shù)字:“^d{n}$”
          只能輸入至少n位數(shù)字:“^d{n,}$”
          只能輸入m-n位的數(shù)字:“^d{m,n}$”
          只能輸入零和非零開頭的數(shù)字:“^(0|[1-9][0-9]*)$”
          只能輸入有兩位小數(shù)的正實(shí)數(shù):“^[0-9]+(.[0-9]{2})?$”
          只能輸入有1-3位小數(shù)的正實(shí)數(shù):“^[0-9]+(.[0-9]{1,3})?$”
          只能輸入非零的正整數(shù):“^+?[1-9][0-9]*$”
          只能輸入非零的負(fù)整數(shù):“^-[1-9][0-9]*$”
          只能輸入長(zhǎng)度為3的字符:“^.{3}$”
          只能輸入由26個(gè)英文字母組成的字符串:“^[A-Za-z]+$”
          只能輸入由26個(gè)大寫英文字母組成的字符串:“^[A-Z]+$”
          只能輸入由26個(gè)小寫英文字母組成的字符串:“^[a-z]+$”
          只能輸入由數(shù)字和26個(gè)英文字母組成的字符串:“^[A-Za-z0-9]+$”
          只能輸入由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串:“^w+$”
          驗(yàn)證用戶密碼:“^[a-zA-Z]w{5,17}$”正確格式為:以字母開頭,長(zhǎng)度在6-18之間,

          只能包含字符、數(shù)字和下劃線。
          驗(yàn)證是否含有^%&’,;=?$”等字符:“[^%&',;=?$x22]+”
          只能輸入漢字:“^[u4e00-u9fa5],{0,}$”
          驗(yàn)證Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”
          驗(yàn)證InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”
          驗(yàn)證電話號(hào)碼:“^((d{3,4})|d{3,4}-)?d{7,8}$”

          正確格式為:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,

          “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。
          驗(yàn)證身份證號(hào)(15位或18位數(shù)字):“^d{15}|d{}18$”
          驗(yàn)證一年的12個(gè)月:“^(0?[1-9]|1[0-2])$”正確格式為:“01”-“09”和“1”“12”
          驗(yàn)證一個(gè)月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”

          正確格式為:“01”“09”和“1”“31”。

          匹配中文字符的正則表達(dá)式: [u4e00-u9fa5]
          匹配雙字節(jié)字符(包括漢字在內(nèi)):[^x00-xff]
          匹配空行的正則表達(dá)式:n[s| ]*r
          匹配HTML標(biāo)記的正則表達(dá)式:/< (.*)>.*|< (.*) />/
          匹配首尾空格的正則表達(dá)式:(^s*)|(s*$)
          匹配Email地址的正則表達(dá)式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
          匹配網(wǎng)址URL的正則表達(dá)式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

          (1)應(yīng)用:計(jì)算字符串的長(zhǎng)度(一個(gè)雙字節(jié)字符長(zhǎng)度計(jì)2,ASCII字符計(jì)1)
          String.prototype.len=function(){return this.replace([^x00-xff]/g,”aa”).length;}

          (2)應(yīng)用:javascript中沒有像vbscript那樣的trim函數(shù),我們就可以利用這個(gè)表達(dá)式來實(shí)現(xiàn)
          String.prototype.trim = function()
          {
          return this.replace(/(^s*)|(s*$)/g, “”);
          }
          (3)應(yīng)用:利用正則表達(dá)式分解和轉(zhuǎn)換IP地址
          function IP2V(ip) //IP地址轉(zhuǎn)換成對(duì)應(yīng)數(shù)值
          {
          re=/(d+).(d+).(d+).(d+)/g //匹配IP地址的正則表達(dá)式
          if(re.test(ip))
          {
          return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
          }
          else
          {
          throw new Error(”Not a valid IP address!”)
          }
          }
          (4)應(yīng)用:從URL地址中提取文件名的javascript程序
          s=”http://www.9499.net/page1.htm”;
          s=s.replace(/(.*/){0,}([^.]+).*/ig,”$2″) ; //Page1.htm
          (5)應(yīng)用:利用正則表達(dá)式限制網(wǎng)頁表單里的文本框輸入內(nèi)容
          用正則表達(dá)式限制只能輸入中文:onkeyup=”value=”/blog/value.replace(/["^u4E00-u9FA5]/g,”) ” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^u4E00-u9FA5]/g,”))”
          用正則表達(dá)式限制只能輸入全角字符: onkeyup=”value=”/blog/value.replace(/["^uFF00-uFFFF]/g,”) ” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^uFF00-uFFFF]/g,”))”
          用正則表達(dá)式限制只能輸入數(shù)字:onkeyup=”value=”/blog/value.replace(/["^d]/g,”) “onbeforepaste= “clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^d]/g,”))”
          用正則表達(dá)式限制只能輸入數(shù)字和英文:onkeyup=”value=”/blog/value.replace(/[W]/g,””) “onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^d]/g,”

          posted @ 2009-04-14 16:21 付學(xué)亮 閱讀(222) | 評(píng)論 (1)編輯 收藏
          CALENDER
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          公告

          常用鏈接

          留言簿(4)

          隨筆檔案

          文章檔案

          相冊(cè)

          我的java

          搜索

          •  

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜


          Powered By: 博客園
          模板提供滬江博客

          主站蜘蛛池模板: 齐齐哈尔市| 静安区| 敖汉旗| 贡山| 政和县| 靖江市| 昂仁县| 文登市| 宝坻区| 深圳市| 鄯善县| 慈利县| 什邡市| 静海县| 沁水县| 海安县| 桐庐县| 高唐县| 涪陵区| 重庆市| 蓬安县| 永顺县| 平远县| 石台县| 阿拉善右旗| 电白县| 抚州市| 张北县| 曲麻莱县| 临夏市| 祁东县| 静安区| 额敏县| 常德市| 邯郸市| 凤山县| 闸北区| 潜江市| 古蔺县| 神木县| 海兴县|