Como consultar MySQL like? O uso da declaración like na base de datos MySQL

mysql Como consultar como?base de datos mysqlO chinés como o uso de declaracións

Cláusula LIKE de MySQL

Sabemos usar o comando SQL SELECT para ler datos en MySQL, e podemos usar a cláusula WHERE na instrución SELECT para obter os rexistros especificados.

O signo igual pódese usar na cláusula WHERE = Para establecer as condicións para obter datos, como "chenweiliang_author = 'chenweiliang.com'".

Pero ás veces necesitamos obter todos os rexistros cuxo campo chenweiliang_author conteña caracteres "COM", entón necesitamos usar a cláusula SQL LIKE na cláusula WHERE.

Usando signos de porcentaxe en cláusulas LIKE de SQL %carácter para representar calquera carácter, semellante ao asterisco en UNIX ou expresións regulares *.

Se non se utiliza ningún signo de porcentaxe %, cláusula LIKE con signo de igual = O efecto é o mesmo.

gramática

A seguinte é a sintaxe xeral dunha instrución SQL SELECT para ler datos dunha táboa de datos mediante a cláusula LIKE:

SELECT field1, field2,...fieldN 
FROM table_name
WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
  • Podes especificar calquera condición na cláusula WHERE.
  • Podes usar a cláusula LIKE na cláusula WHERE.
  • Podes usar a cláusula LIKE en lugar do signo de igual =.
  • LIKE adoita asociarse con % Usados ​​xuntos, de xeito similar á busca de metacaracteres.
  • Podes especificar unha ou máis condicións usando AND ou OU.
  • Podes usar a cláusula WHERE...LIKE nos comandos DELETE ou UPDATE para especificar condicións.

Usando a cláusula LIKE no símbolo do sistema

A continuación usaremos a cláusula WHERE...LIKE no comando SQL SELECT para ler datos da táboa de datos MySQL chenweiliang_tbl.

exemplo

O seguinte é como obteremos o campo chenweiliang_author na táboa chenweiliang_tbl con CON para todos os rexistros que rematan con:

Instrucción SQL UPDATE:

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)

Usando a cláusula LIKE no script PHP

Podes usar a función PHP mysqli_query() e o mesmo comando SQL SELECT cunha cláusula WHERE...LIKE para obter datos.

Esta función utilízase para executar comandos SQL e despois producir datos para todas as consultas mediante a función PHP mysqli_fetch_assoc().

Pero se é unha instrución SQL que usa a cláusula WHERE...LIKE en DELETE ou UPDATE, non hai necesidade de usar a función mysqli_fetch_array().

exemplo

Así é como usamos un script PHP para ler todos os rexistros que rematan en COM no campo chenweiliang_author da táboa chenweiliang_tbl:

Proba de cláusula DELETE de MySQL:

 
<?
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);
?>

发表 评论

O teu enderezo de correo electrónico non será publicado. Utilízanse os campos obrigatorios * Etiqueta

Volver arriba