我們開發資料庫應用時,常常需要用到模糊查詢。如果同乙個條件需要匹配很多字段怎麼辦呢?通常,程式設計師會每個欄位都在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 [email protected] 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表
以下為引用的內容:
thinkphp中的多字段模糊匹配
user m user 例項化user物件 map name title thinkphp 把查詢條件傳入查詢方法 user where map select 用到專案中 if address 這裡就很簡單的解決了這個需求,而且很精準。生成的sql語句如下 select a.b.name,b.tel...
多欄位模糊匹配關鍵字查詢
我們開發資料庫應用時,常常需要用到模糊查詢。如果同乙個條件需要匹配很多字段怎麼辦呢?通常,程式設計師會每個欄位都在sql中 field like cond 一次。這樣,sql語句會長得驚人,碰上覆雜一點的,甚至sql語句會因為超長而被資料庫拒絕執行。其實,這個問題只要動動腦筋就很容易解決 首先,將要...
mysql查詢多欄位 mysql多欄位模糊查詢
在最近的乙個專案需要實現在mysql單錶多關鍵字模糊查詢,但這數個關鍵字並不一定都存在於某個字段。例如現有table表,其中有title,tag,description三個字段,分別記錄一條資料的標題,標籤和介紹。然後根據使用者輸入的查詢請求,將輸入的字串通過空格分割為多個關鍵字,再在這三個欄位中查...