Artikelverzeichnis
mysql Wie kann man abfragen?MySQL-DatenbankChinesen mögen die Verwendung von Anweisungen
MySQL LIKE-Klausel
Wir wissen, wie man den SQL SELECT-Befehl verwendet, um Daten in MySQL zu lesen, und wir können die WHERE-Klausel in der SELECT-Anweisung verwenden, um die angegebenen Datensätze zu erhalten.
Das Gleichheitszeichen kann in der WHERE-Klausel verwendet werden = Zum Festlegen der Bedingungen zum Abrufen von Daten, z. B. „chenweiliang_author = ‚chenweiliang.com‘“.
Aber manchmal müssen wir alle Datensätze abrufen, deren chenweiliang_author-Feld „COM“-Zeichen enthält, dann müssen wir die SQL LIKE-Klausel in der WHERE-Klausel verwenden.
Verwenden von Prozentzeichen in SQL LIKE-Klauseln %Zeichen, um ein beliebiges Zeichen darzustellen, ähnlich dem Sternchen in UNIX oder regulären Ausdrücken *.
Wenn kein Prozentzeichen verwendet wird %, LIKE-Klausel mit Gleichheitszeichen = Der Effekt ist derselbe.
Grammatik
Das Folgende ist die allgemeine Syntax einer SQL SELECT-Anweisung zum Lesen von Daten aus einer Datentabelle unter Verwendung der LIKE-Klausel:
SELECT field1, field2,...fieldN FROM table_name WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
- Sie können jede Bedingung in der WHERE-Klausel angeben.
- Sie können die LIKE-Klausel in der WHERE-Klausel verwenden.
- Sie können die LIKE-Klausel anstelle des Gleichheitszeichens verwenden =.
- LIKE wird normalerweise mit assoziiert % Zusammen verwendet, ähnlich einer Metazeichensuche.
- Sie können eine oder mehrere Bedingungen mit AND oder OR angeben.
- Sie können die WHERE...LIKE-Klausel in DELETE- oder UPDATE-Befehlen verwenden, um Bedingungen anzugeben.
Verwenden der LIKE-Klausel in der Eingabeaufforderung
Im Folgenden verwenden wir die WHERE...LIKE-Klausel im SQL SELECT-Befehl, um Daten aus der MySQL-Datentabelle chenweiliang_tbl zu lesen.
Beispiel
Im Folgenden erfahren Sie, wie wir das Feld chenweiliang_author in der Tabelle chenweiliang_tbl erhalten COM für alle Datensätze, die mit:
SQL-UPDATE-Anweisung:
mysql> use chenweiliang; Database changed mysql> SELECT * from chenweiliang_tbl WHERE chenweiliang_author LIKE '%COM'; +-----------+---------------+---------------+-----------------+ | chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date | +-----------+---------------+---------------+-----------------+ | 3 | 学习 Java | chenweiliang.com | 2015-05-01 | | 4 | 学习 Python | chenweiliang.com | 2016-03-06 | +-----------+---------------+---------------+-----------------+ 2 rows in set (0.01 sec)
Verwendung der LIKE-Klausel im PHP-Skript
Sie können die PHP-Funktion mysqli_query() und denselben SQL-SELECT-Befehl mit einer WHERE...LIKE-Klausel verwenden, um Daten abzurufen.
Diese Funktion wird verwendet, um SQL-Befehle auszuführen und dann Daten für alle Abfragen über die PHP-Funktion mysqli_fetch_assoc() auszugeben.
Wenn es sich jedoch um eine SQL-Anweisung handelt, die die Klausel WHERE...LIKE in DELETE oder UPDATE verwendet, besteht keine Notwendigkeit, die Funktion mysqli_fetch_array() zu verwenden.
Beispiel
So verwenden wir ein PHP-Skript, um alle Datensätze, die mit COM enden, im Feld chenweiliang_author in der Tabelle chenweiliang_tbl zu lesen:
Test der MySQL-DELETE-Klausel:
<?
php
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn , "set names utf8");
$sql = 'SELECT chenweiliang_id, chenweiliang_title,
chenweiliang_author, submission_date
FROM chenweiliang_tbl
WHERE chenweiliang_author LIKE "%COM"';
mysqli_select_db( $conn, 'chenweiliang' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
die('无法读取数据: ' . mysqli_error($conn));
}
echo '<h2>陈沩亮博客 mysqli_fetch_array 测试<h2>';
echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
while($row = mysqli_fetch_array($retval, MYSQL_ASSOC))
{
echo "<tr><td> {$row['chenweiliang_id']}</td> ".
"<td>{$row['chenweiliang_title']} </td> ".
"<td>{$row['chenweiliang_author']} </td> ".
"<td>{$row['submission_date']} </td> ".
"</tr>";
}
echo '</table>';
mysqli_close($conn);
?>Hoffnung Chen Weiliang Blog ( https://www.chenweiliang.com/ ) teilte "How to query MySQL like? The use of like statement in MySQL database", was für Sie hilfreich ist.
Willkommen, um den Link dieses Artikels zu teilen:https://www.chenweiliang.com/cwl-474.html
