有這麼一個需求,滿足只有一個輸入框的條件下,支持不同數據列的搜索結果。 說白了,就是這個 輸入框 既可以用來 搜索姓名,也可以搜索 年齡,地址等。 分析: 一般情況下,我們的一個輸入框對應 資料庫 的某一列信息的搜索,比如,要搜索姓名為 ‘李’ 姓開頭的,那麼對應的 sql 就是 where nam ...
有這麼一個需求,滿足只有一個輸入框的條件下,支持不同數據列的搜索結果。
說白了,就是這個 輸入框 既可以用來 搜索姓名,也可以搜索 年齡,地址等。
分析:
一般情況下,我們的一個輸入框對應 資料庫 的某一列信息的搜索,比如,要搜索姓名為 ‘李’ 姓開頭的,那麼對應的 sql 就是
where name like '李%'
但是,現在輸入框有了不確定性,不知道用戶到底會輸入什麼,導致我們後臺的 sql 不知道該如何對應了,
比如,用戶輸入 18,很明顯,用戶是想搜索 年齡為 18 的用戶,如果 後臺sql 還是 where name like '18%',那麼就會 搜索不到內容了。
方案一:
我們可以用 or 這種關鍵字來實現 多欄位匹配,
比如:where name like '%搜索內容%' or age like '%搜索內容%'
這種方案對於 搜索欄位比較 少的可以嘗試,但是效率不高。
方案二:推薦
我們可以換一種思路
假設我們的資料庫每一行都有一個完整的列 (colum),這個列的內容為 該行所有欄位的內容。
那麼我們搜索的sql 的可以改寫為 where colum like '%搜索內容%'
這樣 不論搜索 姓名 ,還是 年齡,地址 等,我們都可以查到。
既然到這裡了,我相信你已經明白該怎麼做了。
其實,就是用 sql 把需要可能 被用戶搜索的 資料庫欄位拼接 起來,然後再 like '%搜索內容%' 就可以了。
oracle 做法
可以採用 instr() 函數,這裡說下 INSTR()函數的作用
INSTR(參數1,參數2)其實是一個查找字元串的函數,返回的是字元串查找的位置,它有兩個參數都是字元類型,如果找到則返回參數2在參數1中的位置,如果沒有找到則返回 0。
SELECT INSTR('abcde', 'a') FROM DUAL;
--------------------------------------------
1
--------------------------------------------
結果分析,因為a在abcde的第一個位置,所以返回1
SELECT INSTR('abcde', 'f') FROM DUAL;
--------------------------------------------
0
--------------------------------------------
結果分析,因為f在abcde串中找不到,所以返回0
這裡 對比 like 與 instr() 函數, 如果對性能 要求比較嚴格的 童鞋,記得來這裡 用 instr () 來 替換 like 關鍵字
colum like '%搜索內容%'
等價於
instr(colum, '搜索內容', 1, 1)>0
colum like '搜索內容%'
等價於
instr(colum, '搜索內容', 1, 1)=1
colum like '%搜索內容'
等價於
instr(colum, '搜索內容', 1, -1)=length(colum)-length('搜索內容')+1
sql:
oracle || 代表拼接多個 資料庫列
一般情況:where instr(姓名||年齡||地址,'搜索內容',1,1) > 0
如果兩個數據列相鄰,採用 ',' 分割,防止搜索到不匹配內容:
where instr(姓名|| ',' || 年齡|| ',' || 地址 ,'搜索內容',1,1) > 0
如果欄位為空,可以用 nvl (欄位名,''),來處理,他的意思是 用 ‘’代替 空的內容
mysql
concat 拼接多個資料庫 列
instr 查詢
where instr (concat(姓名,年齡,地址),'搜索內容') > 0