自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle模糊查詢的實(shí)現(xiàn)

數(shù)據(jù)庫(kù) Oracle
模糊查詢對(duì)于每一個(gè)數(shù)據(jù)庫(kù)來(lái)說,都是比較難實(shí)現(xiàn)的,下文對(duì)Oracle數(shù)據(jù)庫(kù)模糊查詢的實(shí)現(xiàn)方法作了詳細(xì)的描述,供您參考。

Oracle模糊查詢應(yīng)該如何實(shí)現(xiàn)呢?下面就教您一個(gè)實(shí)現(xiàn)Oracle模糊查詢的方法,如果您在Oracle模糊查詢方面遇到問題,不妨一看。

在Where子句中,可以對(duì)datetime、char、varchar字段類型的列用Like子句配合通配符選取那些“很像...”的數(shù)據(jù)記錄,以下是可使用的通配符:
%   零或者多個(gè)字符
_    單一任何字符(下劃線)
\     特殊字符
[]     在某一范圍內(nèi)的字符,如[0-9]或者[aeth]
[^]    不在某范圍內(nèi)的字符,如[^0-9]或者[^aeth]

其中關(guān)于條件,SQL提供了四種匹配模式:

1,%:表示任意0個(gè)或多個(gè)字符??善ヅ淙我忸愋秃烷L(zhǎng)度的字符,有些情況下若是中文,請(qǐng)使用兩個(gè)百分號(hào)(%%)表示。

比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'

將會(huì)把u_name為“張三”,“張貓三”、“三腳貓”,“唐三藏”等等有“三”的記錄全找出來(lái)。

另外,如果需要找出u_name中既有“三”又有“貓”的記錄,請(qǐng)使用and條件
SELECT * FROM [user] WHERE u_name LIKE '%三%' AND u_name LIKE '%貓%'

若使用 SELECT * FROM [user] WHERE u_name LIKE '%三%貓%'
雖然能搜索出“三腳貓”,但不能搜索出符合條件的“張貓三”。

2,_: 表示任意單個(gè)字符。匹配單個(gè)任意字符,它常用來(lái)限制表達(dá)式的字符長(zhǎng)度語(yǔ)句:

比如 SELECT * FROM [user] WHERE u_name LIKE '_三_'
只找出“唐三藏”這樣u_name為三個(gè)字且中間一個(gè)字是“三”的;

再比如 SELECT * FROM [user] WHERE u_name LIKE '三__';
只找出“三腳貓”這樣name為三個(gè)字且第一個(gè)字是“三”的;

3,[ ]:表示括號(hào)內(nèi)所列字符中的一個(gè)(類似正則表達(dá)式)。指定一個(gè)字符、字符串或范圍,要求所匹配對(duì)象為它們中的任一個(gè)。

比如 SELECT * FROM [user] WHERE u_name LIKE '[張李王]三'
將找出“張三”、“李三”、“王三”(而不是“張李王三”);

如 [ ] 內(nèi)有一系列字符(01234、abcde之類的)則可略寫為“0-4”、“a-e”
SELECT * FROM [user] WHERE u_name LIKE '老[1-9]'
將找出“老1”、“老2”、……、“老9”;

4,[^ ] :表示不在括號(hào)所列之內(nèi)的單個(gè)字符。其取值和 [] 相同,但它要求所匹配對(duì)象為指定字符以外的任一個(gè)字符。

比如 SELECT * FROM [user] WHERE u_name LIKE '[^張李王]三'
將找出不姓“張”、“李”、“王”的“趙三”、“孫三”等;

SELECT * FROM [user] WHERE u_name LIKE '老[^1-4]';
將排除“老1”到“老4”,尋找“老5”、“老6”、……

5,查詢內(nèi)容包含通配符時(shí)

由于通配符的緣故,導(dǎo)致我們查詢特殊字符“%”、“_”、“[”的語(yǔ)句無(wú)法正常實(shí)現(xiàn),而把特殊字符用“[ ]”括起便可正常查詢。據(jù)此我們寫出以下函數(shù):

  1. function sqlencode(str)  
  2. str=replace(str,"[","[[]") '此句一定要在最前  
  3. str=replace(str,"_","[_]")  
  4. str=replace(str,"%","[%]")  
  5. sqlencode=str 
  6. end function 

在查詢前將待查字符串先經(jīng)該函數(shù)處理即可。

 

 

 

【編輯推薦】

Oracle存儲(chǔ)過程的調(diào)試方法

帶您了解Oracle物理結(jié)構(gòu)

Oracle自動(dòng)歸檔模式的設(shè)置

ORACLE歸檔日志刪除方法

Oracle移動(dòng)數(shù)據(jù)文件的方法

責(zé)任編輯:段燃 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-11-18 16:27:37

2010-10-27 17:00:32

oracle樹查詢

2009-07-22 11:27:36

iBATIS模糊查詢

2010-10-27 16:39:23

oracle查詢

2010-10-28 16:52:11

oracle多列子查詢

2010-11-22 13:13:30

MySQL模糊查詢

2010-10-27 14:41:45

Oracle查詢用戶表

2010-10-27 13:16:41

oracle并行查詢

2010-10-08 15:37:21

MySQL單表

2010-09-17 10:08:18

SQL中case wh

2023-11-17 15:34:03

Redis數(shù)據(jù)庫(kù)

2009-09-14 18:06:18

LINQ模糊查詢

2009-06-25 16:45:31

Hibernate

2010-10-27 17:16:51

Oracle查詢

2010-11-24 10:35:34

MySQL單表多字段

2009-09-14 18:19:49

LINQ模糊查詢

2023-10-12 08:22:21

2010-10-28 17:08:11

Oracle查詢

2009-09-14 17:03:32

LINQ模糊查詢

2009-07-24 16:59:57

iBatis模糊查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)