SQL“多欄位模糊匹配關鍵字查詢”
我們開發資料庫應用時,常常需要用到模糊查詢。如果同一個條件需要匹配很多欄位怎麼辦呢?通常,程式設計師會每個欄位都在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%df%"
多表的情況意思是說where子句先寫連線子句進行過濾再寫連線like語句進行檢索
比如:
SELECT * FROM line_items l,orders o where l.order_id=o.id and concat(l.quantity,o.email) like "3%like%"
其中line_items表
以下為引用的內容: create table line_items ( id int not null auto_increment, product_id int not null, order_id int not null, quantity int not null default 0, unit_price decimal(10,2) not null, constraint fk_items_product foreign key (product_id) references products(id), constraint fk_items_order foreign key (order_id) references orders(id), primary key (id) ); |
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-605020/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL簡單實現多欄位模糊查詢MySql
- 多個值以,分隔儲存在一個欄位精確匹配查詢 sql語句SQL
- mysql like查詢 - 根據多個條件的模糊匹配查詢MySql
- lucene 多欄位查詢-MultiFieldQueryParser
- Dapper 中使用sql in 關鍵字查詢APPSQL
- 小程式雲開發模糊查詢,實現資料庫多欄位的模糊搜尋資料庫
- mysql sql同一個欄位多個行轉成一個欄位查詢MySql
- Elasticsearch 單字串多欄位查詢Elasticsearch字串
- sql根據多個欄位查詢重複記錄SQL
- Elasticsearch 複合查詢——多字串多欄位查詢Elasticsearch字串
- 查詢外來鍵約束、子表欄位等資訊的SQLSQL
- sql日期模糊查詢SQL
- mysql帶AND關鍵字的多條件查詢MySql
- Lucene多欄位查詢&高亮顯示
- sql 模糊查詢問題SQL
- mybatis利用example檔案進行異表欄位模糊查詢MyBatis
- SQL Server 查詢表註釋和欄位SQLServer
- mysql多表多欄位查詢並去重MySql
- clob 欄位查詢
- mysql帶IN關鍵字的查詢MySql
- [Elasticsearch] 多欄位搜尋 (二) - 最佳欄位查詢及其調優(轉)Elasticsearch
- mysql正則匹配解決查詢一個欄位是否在另一個欄位中MySql
- 請問mysql裡面的text欄位怎麼進行模糊查詢MySql
- [Mysql 查詢語句]——查詢欄位MySql
- 將查詢的關鍵字返紅
- 關於日期及時間欄位的查詢
- Excel 2010 SQL應用032 字元範圍的模糊匹配查詢ExcelSQL字元
- Native for sql 查詢列欄位非命令列形式SQL命令列
- SQL查詢列(欄位)重複值及操作--整理SQL
- SQL查詢關鍵字執行順序及記憶口訣SQL
- 在 with 查詢中只查詢個別欄位
- 根據關鍵字查詢車輛資訊
- 在資料庫中查詢關鍵字資料庫
- ORACLE 查詢條件出現關鍵字:&Oracle
- MySQL查詢某個欄位含有字母數字的值MySql
- where語句中多條件查詢欄位NULL與NOT NULL不確定性查詢Null
- SQL2005查詢表中欄位的描述SQL
- SQL使用模糊查詢like的優化SQL優化