mysql模糊查詢like和regexp小結(jié)
在mysql中實現(xiàn)模糊查詢的有l(wèi)ike和regexp。
------------------------
like的用法許多人都是知道的,最為常用的情況就是select * from a where name like '%a%';
其中'%'代表的是任意個字符,它的效果像是正則表達(dá)式里的'*',它有幾種用法:'a%','%a%','%a',分別表示以什么開頭,存在什么以及以什么結(jié)尾。
另外也可以使用'_'字符,這表示一個任意字符。效果類似正則表達(dá)式里面的'.'。
like是對這個字段里面的所有字符串進(jìn)行比較,效率并不高。
------------------------
regexp就是mysql的正則匹配操作符.
regexp的用法如:select * from a where name regexp 'a';其寫法可以參照正則表達(dá)式.像是'*','[a-z]','a|b','cc$','^b{2}$'。
------------------------
在hibernate中沒有提供regexp的直接使用功能,但是可以通過添加自定義函數(shù)的方式實現(xiàn)。
public class MySQL5DialectRegexp extends org.hibernate.dialect.MySQLInnoDBDialect{ public MySQL5DialectRegexp() { super(); registerFunction( "regexp", new SQLFunctionTemplate(Hibernate.BOOLEAN, "?1 REGEXP ?2") ); } }
其中org.hibernate.dialect.MySQLInnoDBDialect是hibernate配置信息hibernate.dialect的值,之后可以使用MySQL5DialectRegexp的路徑代替.
HQL語句可以寫作:
from A where regexp(a,'a|b|c')=1;
相關(guān)文章
PHP5 mysqli的prepare準(zhǔn)備語句使用說明
mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,它極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性.prepare準(zhǔn)備語句分為綁定參數(shù)和綁定結(jié)果2012-12-12MySQL數(shù)據(jù)庫基礎(chǔ)篇之入門基礎(chǔ)命令小結(jié)
這篇文章主要介紹了MySQL數(shù)據(jù)庫入門基礎(chǔ)命令,總結(jié)分析了mysql數(shù)據(jù)庫基本創(chuàng)建、刪除、查看、權(quán)限等相關(guān)操作技巧與注意事項,需要的朋友可以參考下2020-05-05MySQL無法讀表錯誤的解決方法(MySQL 1018 error)
這篇文章主要為大家詳細(xì)介紹了MySQL無法讀表錯誤的解決方法,MySQL 1018 error如何解決?具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01MyEclipse通過JDBC連接MySQL數(shù)據(jù)庫基本介紹
MyEclipse使用Java 通過JDBC連接MySQL數(shù)據(jù)庫的基本測試前提是MyEclipse已經(jīng)能正常開發(fā)Java工程2012-11-11MySQL數(shù)據(jù)時區(qū)問題以及datetime和timestamp類型存儲的差異
這篇文章主要介紹了MySQL數(shù)據(jù)時區(qū)問題以及datetime和timestamp類型存儲的差異,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11Linux mysql命令安裝允許遠(yuǎn)程連接的安裝設(shè)置方法
對大家推薦很好使用的Linux mysql系統(tǒng),像讓大家對Linux mysql系統(tǒng)有所了解,然后對Linux mysql系統(tǒng)全面講解介紹,希望對大家有用今天特意配置了mysql apache php ,雖然網(wǎng)上很多這方面的例子,但是很多是作者再回憶寫的,所以難免有筆誤的地方。2010-08-08