Mysql高效的模糊查詢(轉)

BSDLite發表於2007-08-12
Mysql高效的模糊查詢(轉)[@more@]  我們開發資料庫應用時,常常需要用到模糊查詢。如果同一個條件需要匹配很多欄位怎麼辦呢?通常,程式設計師會每個欄位都在 SQL 中“field like '%cond%'”一次。這樣,SQL語句會長得驚人,碰上覆雜一點的,甚至SQL語句會因為超長而被資料庫拒絕執行。

  其實,這個問題只要動動腦筋就很容易解決:

  首先,將要匹配相同條件的欄位連起來(field1+field2+...)成一個長字串;然後再 Like “%cond%”就可以了。

  不過這種方法有個問題,就是得權衡多表連線造成的效率降低。一般來說,單表內欄位肯定應該連線後再統一 like 判斷;表間欄位,則需要先過濾後,再實行這個策略。

  採取這個策略,不僅可以縮短 SQL,而且能夠有效地提高SQL的執行效率。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617542/viewspace-948991/,如需轉載,請註明出處,否則將追究法律責任。

相關文章