国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SQL“多字段模糊匹配關鍵字查詢”

2024-08-31 00:45:59
字體:
來源:轉載
供稿:網友

我們開發數據庫應用時,常常需要用到模糊查詢。如果同一個條件需要匹配很多字段怎么辦呢?通常,程序員會每個字段都在SQL中“field like'%cond%'”一次。這樣,SQL語句會長得驚人,碰上復雜一點的,甚至SQL語句會因為超長而被數據庫拒絕執行。其實,這個問題只要動動腦筋就很容易解決:首先,將要匹配相同條件的字段連起來(field1 field2 ...)成一個長字符串;然后再 Like “%cond%”就可以了。不過這種方法有個問題,就是得權衡多表連接造成的效率降低。一般來說,單表內字段肯定應該連接后再統一like判斷;表間字段,則需要先過濾后,再實行這個策略。采取這個策略,不僅可以縮短SQL,而且能夠有效地提高SQL的執行效率。

例:

以下為引用的內容:
QUOTE:
create table orders (

id int not null auto_increment,

name varchar(100) not null,

email varchar(255) not null,

address text not null,

pay_type char(10) not null,

shipped_at datetime null,

primary key (id)

);

里面有數據
1 aaa aaa@gmail.com beijing cc 2006-10-11 16:17:26

現在想要查找出email為aaa開頭的,address為bei開頭的記錄

那么一般我們會構建如下SQL
select * from orders o where o.email like "aaa%" and o.address like "bei%"

其實我們可以使用如下SQL來縮短SQL語句(也就是連接字段一起進行like操作)
SELECT * FROM orders o where concat(o.email,o.address) like "like

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宝应县| 安徽省| 梁河县| 辽阳市| 兴仁县| 铁岭县| 阳江市| 安吉县| 静宁县| 汤阴县| 天等县| 抚州市| 新干县| 达州市| 雷州市| 苍山县| 广丰县| 延寿县| 西吉县| 安仁县| 宣武区| 含山县| 辛集市| 金堂县| 呼和浩特市| 库伦旗| 郴州市| 长沙县| 寻乌县| 三台县| 库车县| 衢州市| 泗洪县| 房山区| 从江县| 丽水市| 邹城市| 巨鹿县| 中西区| 江北区| 马龙县|