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

          2009年4月29日

          新一篇: 利用WatiN自動化網(wǎng)站功能測試 | 舊一篇: 代碼自動生成工具MyGeneration之三
          前面學(xué)過了基本的存儲過程,見

          存儲過程入門

          現(xiàn)在學(xué)一下常用的存儲過程的語法,只要花一點點時間學(xué)習(xí)下,就能用存儲過程實現(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,安裝后,到默認目錄C:\SQL Server 2000 Sample Databases 有instnwnd.sql ,instpubs.sql兩個文件
          3,在sql server中運行這兩個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 --申明一個名為@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,如果要達到這樣的功能,可以這樣寫:

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


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


          以下必要時候省略變量申明
          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
          將多條語句作為一個塊,類似與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í)行其他存儲過程 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

          十一.游標

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


          語法:
          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) –申明變量
          --申明一個游標
          DECLARE authors_cursor CURSOR FOR
          SELECT au_id, au_fname FROM authors
          --打開游標
          OPEN authors_cursor
          --取出值
          FETCH NEXT FROM authors_cursor INTO @au_id, @au_fname
          --循環(huán)取出游標的值
          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)閉游標
          DEALLOCATE authors_cursor --釋放游標
          我覺得上面的是存儲過程常用的一些東東,如果要更深入的了解,更詳細的幫助,請參考SQL Server的幫助文檔
          posted @ 2009-04-29 11:42 付學(xué)亮 閱讀(609) | 評論 (0)編輯 收藏

          2009年4月14日

          下面都是我收集的一些比較常用的正則表達式,因為平常可能在表單驗證的時候,用到的比較多。特發(fā)出來,讓各位朋友共同使用。呵呵。

          匹配中文字符的正則表達式: [u4e00-u9fa5]
          評注:匹配中文還真是個頭疼的事,有了這個表達式就好辦了

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

          匹配空白行的正則表達式:ns*r
          評注:可以用來刪除空白行

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

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

           

          匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
          評注:表單驗證時很實用

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

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

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

          匹配騰訊QQ號:[1-9][0-9]{4,}
          評注:騰訊QQ號從10000開始

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

          匹配身份證:d{15}|d{18}
          評注:中國的身份證為15位或18位

          匹配ip地址:d+.d+.d+.d+
          評注:提取ip地址時有用

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

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

          在使用RegularExpressionValidator驗證控件時的驗證功能及其驗證表達式介紹如下:

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

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

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

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

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

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

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

          (2)應(yīng)用:javascript中沒有像vbscript那樣的trim函數(shù),我們就可以利用這個表達式來實現(xiàn)
          String.prototype.trim = function()
          {
          return this.replace(/(^s*)|(s*$)/g, “”);
          }
          (3)應(yīng)用:利用正則表達式分解和轉(zhuǎn)換IP地址
          function IP2V(ip) //IP地址轉(zhuǎn)換成對應(yīng)數(shù)值
          {
          re=/(d+).(d+).(d+).(d+)/g //匹配IP地址的正則表達式
          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)用:利用正則表達式限制網(wǎng)頁表單里的文本框輸入內(nèi)容
          用正則表達式限制只能輸入中文:onkeyup=”value=”/blog/value.replace(/["^u4E00-u9FA5]/g,”) ” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^u4E00-u9FA5]/g,”))”
          用正則表達式限制只能輸入全角字符: onkeyup=”value=”/blog/value.replace(/["^uFF00-uFFFF]/g,”) ” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^uFF00-uFFFF]/g,”))”
          用正則表達式限制只能輸入數(shù)字:onkeyup=”value=”/blog/value.replace(/["^d]/g,”) “onbeforepaste= “clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^d]/g,”))”
          用正則表達式限制只能輸入數(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é)亮 閱讀(223) | 評論 (1)編輯 收藏
          CALENDER
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          公告

          常用鏈接

          留言簿(4)

          隨筆檔案

          文章檔案

          相冊

          我的java

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜


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

          主站蜘蛛池模板: 时尚| 辰溪县| 华安县| 吴堡县| 汤原县| 秦皇岛市| 措勤县| 闽清县| 钟祥市| 贵港市| 花莲市| 黄石市| 拉孜县| 文水县| 武邑县| 明水县| 时尚| 台北市| 福泉市| 东明县| 临泉县| 锡林浩特市| 清水县| 宣汉县| 三亚市| 磴口县| 黄龙县| 丰顺县| 南通市| 上林县| 安达市| 惠东县| 西盟| 南京市| 开阳县| 罗甸县| 城固县| 香港 | 宜川县| 大姚县| 山东省|