欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Mysql中文檢索匹配與正則

系統 1942 0

今天在用sql模糊查詢包含字母d的時候,發現一些不包含此字母的也被查詢出來了:

      
        SELECT
      
      
        *
      
      
        FROM
      
      
         custom


      
      
        WHERE
      
        custom_realname 
      
        LIKE
      
      
        '
      
      
        %d%
      
      
        '
      
    

查詢了一下,發現以下說明:

(最后修改為:

      
        SELECT
      
      
        *
      
      
        FROM
      
      
         custom


      
      
        WHERE
      
        custom_realname 
      
        LIKE
      
      
        BINARY
      
      
        '
      
      
        %d%
      
      
        '
      
    

?

今天在做mysql的一個搜索的時候發現我用 select name from contact where name like '%a%'的時候出來的結果除了包含a的名字外連包含中文“新”的名字也出現在搜索結果里面,這令我想弄清楚mysql的匹配模式和規則到底是怎么樣的,所以決定查查資料了解了解,另外在匹配的時候正則表達式也很常用!所以準備在這里記錄我學習這兩個玩意的收獲!
出現這個問題的原因是:MySQL在查詢字符串時是大小寫不敏感的,在編繹MySQL時一般以ISO-8859字符集作為默認的字符集,因此在比較過程中中文編碼字符大小寫轉換造成了這種現象。


解決辦法:
1 .在建表的時候對于包含中文的字段加上“BINARY”屬性,使之進行二進制比較,例如講"name char(10)"改成"name char(10) BINARY"。但是這樣你對該表的該字段進行匹配的時候是區分大小寫的。


2 .如果使用源碼編譯MySQL,可以在編譯的時候使用--with--charset=gbk參數,這樣mysql就直接支持中文查找和排序。


3 .使用mysql的locate函數來判斷。如:
SELECT * FROM table WHERE locate(substr,str)>0 ;
locate()有兩個形式: LOCATE( substr , str ) ,? LOCATE( substr , str , pos )。 返回substr在str中的位置,如果str不包含substr返回0。這個函數也是不區分大小寫的。


4 .這樣使用sql語句:SELECT * FROM TABLE WHERE FIELDS LIKE BINARY '%FIND%',但是這和1一樣是區分大小寫的如果你想進行不區分大小寫的查詢的時候就要使用upper或者lower進行轉換。


5 .使用binary和ucase函數及concat函數。ucase是講英文全部轉換大寫,concat對字符串進行連接。新的sql語句如下:
select id,title,name from achech_com.news where?binary ucase(title)?like?concat('%',ucase('a'),'%')?
也可以寫為select id,title,name from achech_com.news where binary ucase(title) like ucase('%a%')?
檢索的結果還算滿意吧,不過速度可能會因此而慢N毫秒喔。 因為使用like和%進行匹配的話對效率會有一定的影響。

正則表達式:
正則表達式是為復雜搜索指定模式的強大方式。
^?
所匹配的字符串以后面的字符串開頭?
mysql> select "fonfo" REGEXP "^fo$"; -> 0(表示不匹配)?
mysql> select "fofo" REGEXP "^fo"; -> 1(表示匹配)?
$?
所匹配的字符串以前面的字符串結尾?
mysql> select "fono" REGEXP "^fono$"; -> 1(表示匹配)?
mysql> select "fono" REGEXP "^fo$"; -> 0(表示不匹配)?
.
匹配任何字符(包括新行)?
mysql> select "fofo" REGEXP "^f.*"; -> 1(表示匹配)?
mysql> select "fonfo" REGEXP "^f.*"; -> 1(表示匹配)?
a*?
匹配任意多個a(包括空串)?
mysql> select "Ban" REGEXP "^Ba*n"; -> 1(表示匹配)?
mysql> select "Baaan" REGEXP "^Ba*n"; -> 1(表示匹配)?
mysql> select "Bn" REGEXP "^Ba*n"; -> 1(表示匹配)
?

a+
匹配1個或多個a字符的任何序列。

mysql> select "Ban" REGEXP "^Ba+n"; -> 1(表示匹配)?
mysql> select "Bn" REGEXP "^Ba+n"; -> 0(表示不匹配)

a??
匹配一個或零個a?
mysql> select "Bn" REGEXP "^Ba?n"; -> 1(表示匹配)?
mysql> select "Ban" REGEXP "^Ba?n"; -> 1(表示匹配)?
mysql> select "Baan" REGEXP "^Ba?n"; -> 0(表示不匹配)

de|abc?
匹配de或abc?
mysql> select "pi" REGEXP "pi|apa"; -> 1(表示匹配)?
mysql> select "axe" REGEXP "pi|apa"; -> 0(表示不匹配)?
mysql> select "apa" REGEXP "pi|apa"; -> 1(表示匹配)?
mysql> select "apa" REGEXP "^(pi|apa)$"; -> 1(表示匹配)?
mysql> select "pi" REGEXP "^(pi|apa)$"; -> 1(表示匹配)?
mysql> select "pix" REGEXP "^(pi|apa)$"; -> 0(表示不匹配)

(abc)*?
匹配任意多個abc(包括空串)?
mysql> select "pi" REGEXP "^(pi)*$"; -> 1(表示匹配)?
mysql> select "pip" REGEXP "^(pi)*$"; -> 0(表示不匹配)?
mysql> select "pipi" REGEXP "^(pi)*$"; -> 1(表示匹配)

{1} {2,3}?
這是一個更全面的方法,它可以實現前面好幾種保留字的功能?
a*?
可以寫成a{0,}?
a?
可以寫成a{1,}?
a??
可以寫成a{0,1}?
在{}內只有一個整型參數i,表示字符只能出現i次;在{}內有一個整型參數i,?
后面跟一個“,”,表示字符可以出現i次或i次以上;在{}內只有一個整型參數i,?
后面跟一個“,”,再跟一個整型參數j,表示字符只能出現i次以上,j次以下?
(包括i次和j次)。其中的整型參數必須大于等于0,小于等于 RE_DUP_MAX(默認是25?
5)。 如果同時給定了m和n,m必須小于或等于n.

[a-dX],?[^a-dX]

匹配任何是(或不是,如果使用^的話)a、b、c、d或X的字符。兩個其他字符之間的“-”字符構成一個范圍,與從第1個字符開始到第2個字符之間的所有字符匹配。例如,[0-9]匹配任何十進制數字 。要想包含文字字符“]”,它必須緊跟在開括號“[”之后。要想包含文字字符“-”,它必須首先或最后寫入。對于[]對內未定義任何特殊含義的任何字符,僅與其本身匹配。

mysql> select "aXbc" REGEXP "[a-dXYZ]"; -> 1(表示匹配)?
mysql> select "aXbc" REGEXP "^[a-dXYZ]$"; -> 0(表示不匹配)?
mysql> select "aXbc" REGEXP "^[a-dXYZ] $"; -> 1(表示匹配)?
mysql> select "aXbc" REGEXP "^[^a-dXYZ] $"; -> 0(表示不匹配)?
mysql> select "gheis" REGEXP "^[^a-dXYZ] $"; -> 1(表示匹配)?
mysql> select "gheisa" REGEXP "^[^a-dXYZ] $"; -> 0(表示不匹配)

[[.characters.]]?
表示比較元素的順序。在括號內的字符順序是唯一的。但是括號中可以包含通配符,?
所以他能匹配更多的字符。舉例來說:正則表達式[[.ch.]]*c匹配chchcc的前五個字符?


[=character_class=]?
表示相等的類,可以代替類中其他相等的元素,包括它自己。例如,如果o和( )是?
一個相等的類的成員,那么[[=o=]]、[[=( )=]]和[o( )]是完全等價的。?

[:character_class:]?
在括號里面,在[:和:]中間是字符類的名字,可以代表屬于這個類的所有字符。?
字符類的名字有: alnum、digit、punct、alpha、graph、space、blank、lower、uppe?
r、cntrl、print和xdigit?
mysql> select "justalnums" REGEXP "[[:alnum:]] "; -> 1(表示匹配)?
mysql> select "!!" REGEXP "[[:alnum:]] "; -> 0(表示不匹配)?

alnum

文字數字字符

alpha

文字字符

blank

空白字符

cntrl

控制字符

digit

數字字符

graph

圖形字符

lower

小寫文字字符

print

圖形或空格字符

punct

標點字符

space

空格、制表符、新行、和回車

upper

大寫文字字符

xdigit

十六進制數字字符


[[:<:]]?
[[:>:]]?
分別匹配一個單詞開頭和結尾的空的字符串,這個單詞開頭和結尾都不是包含在alnum中?
的字符也不能是下劃線。?
mysql> select "a word a" REGEXP "[[:<:]]word[[:>:]]"; -> 1(表示匹配)?
mysql> select "a xword a" REGEXP "[[:<:]]word[[:>:]]"; -> 0(表示不匹配)?
mysql> select "weeknights" REGEXP "^(wee|week)(knights|nights)$"; -> 1(表示?
匹配)?
?

?

要想在正則表達式中使用特殊字符的文字實例,應在其前面加上2個反斜杠“/”字符。MySQL解析程序負責解釋其中一個,正則表達式庫負責解釋另一個。例如,要想與包含特殊字符“+”的字符串“1+2”匹配,在下面的正則表達式中,只有最后一個是正確的:

    mysql> 
    
      SELECT '1+2' REGEXP '1+2';
    
                           -> 0
  
    mysql> 
    
      SELECT '1+2' REGEXP '1/+2';
    
                          -> 0
  
    mysql> 
    
      SELECT '1+2' REGEXP '1//+2';
    
                         -> 1
  

Mysql中文檢索匹配與正則


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天天干网 | 国产成人综合欧美精品久久 | 欧美区日韩区 | 日本黄色一级片视频 | 国产一级做人爱c黑人版 | 浮力影院在线观看 | 国产美女被爽到高潮免费A片小说 | 久久精品二区亚洲w码 | 日韩一区二区三区精品 | 污视频免费在线观看 | 黑色丝袜美女自安慰视频 | 久久精品a | 色伊人网 | 国产日韩在线观看一区 | 青草香蕉精品视频在线观看 | 久久久久久网站 | 九九热线有精品视频99 | 久福利 | 久久精片 | 青青在线香蕉精品视频免费看 | 欧美a在线 | 国产精品视频第一页 | 一级@片 | 亚洲欧美一级久久精品 | 国产一区二区精品在线观看 | 国产精品视频第一页 | 狠狠色狠狠色综合日日92 | 欧美一级网站 | 免费国产午夜在线观看 | 午夜精品久久久久久久99黑人 | 性欧美精品久久久久久久 | 日韩精品一区二区三区在线观看 | 久久国产精品久久 | 五月婷婷导航 | 国产精品吹潮在线观看中文 | 黄色羞羞视频在线观看 | 日韩高清中文字幕 | 亚洲精品成人av久久 | 亚洲福利视频一区二区 | 一区二区三区免费视频 www | 久久久久久国产精品免费免费 |