簡體   English   中英

MySQL使用WHERE子句和多個LIKE

[英]MySQL using WHERE clause with multiple LIKEs

我有一個簡單的表,其中包含名稱,有些以字母開頭,有些以數字開頭。 我正在嘗試過濾以數字開頭的名稱,並且僅選擇以字母開頭的名稱。

這是我的一些嘗試,但均未產生預期的結果:

SELECT name 
  from subjects 
 WHERE name LIKE ('A%') AND 
 WHERE name LIKE ('B%') AND 
 WHERE name LIKE ('C%')...;

SELECT name 
  from subjects 
 WHERE name LIKE ('A%', 'B%', 'C%', ...);

SELECT name 
  from subjects 
 WHERE name LIKE ('A%') AND ('B%') AND ('C%') ...;

預先感謝您的幫助。 我非常感激。 堆棧溢出一直是我的救星,因為我正在學習使用PHP和MySQL進行編程。 洛里

一個更簡單的解決方案是使用regexp運算符,而不是傳遞多個like

嘗試:

SELECT name from subjects WHERE name REGEXP '^[a-zA-Z]';

這將選擇名稱以小寫和大寫字母開頭的所有記錄。

您遇到的問題是您包括多個位置。 只需刪除它們

SELECT name 
  from subjects 
 WHERE name LIKE ('A%') AND 
 name LIKE ('B%') AND 
 name LIKE ('C%')...;

嘗試Regexp:

SELECT name 
FROM subjects 
WHERE name
REGEXP '[A-Za-z]'

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM