SQL中代替Like語句的另一種寫法

比如查找用戶名包含有"c"的所有用戶, 可以用

  use mydatabase
  select * from table1 where username like'%c%"


  下面是完成上面功能的另一種寫法:
  use mydatabase
  select * from table1 where charindex('c',username)gt;0
  這種方法理論上比上一種方法多了一個判斷語句,即gt;0, 但這個判斷過程是最快的, 我想信80%以上的運算都是花在查找字符串及其它的運算上, 所以運用charindex函數也沒什麼大不了. 用這種方法也有好處, 那就是對%,|等在不能直接用like查找到的字符中可以直接在這charindex中運用, 如下:
  use mydatabase
  select * from table1 where charindex('%',username)gt;0
  也可以寫成:
  use mydatabase
  select * from table1 where charindex(char(37),username)gt;0
  ASCII的字符即爲%

發佈了129 篇原創文章 · 獲贊 0 · 訪問量 15萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章