MySQL DELETE 語句
你可以使用 SQL 的 DELETE FROM 指令來删除 MySQL 資料表中的記錄。
你可以在 mysql> 指令提示符或 PHP 腳本中執行該指令。
文法
以下是 SQL DELETE 語句從 MySQL 資料表中删除資料的通用文法:
DELETE FROM table_name [WHERE Clause]
- 如果沒有指定 WHERE 子句,MySQL 表中的所有記錄将被删除。
- 你可以在 WHERE 子句中指定任何條件
- 您可以在單個表中一次性删除記錄。
當你想删除資料表中指定的記錄時 WHERE 子句是非常有用的。
從指令行中删除資料
這裡我們将在 SQL DELETE 指令中使用 WHERE 子句來删除 MySQL 資料表 runoob_tbl 所選的資料。
執行個體
以下執行個體将删除 runoob_tbl 表中 runoob_id 為3 的記錄:
SQL UPDATE 語句:
mysql> use RUNOOB;Database changedmysql> DELETE FROM runoob_tbl WHERE runoob_id=3;Query OK, 1 row affected (0.23 sec)
使用 PHP 腳本删除資料
PHP使用 mysqli_query() 函數來執行SQL語句, 你可以在 SQL DELETE 指令中使用或不使用 WHERE 子句。
該函數與 mysql> 指令符執行SQL指令的效果是一樣的。
以下PHP執行個體将删除 runoob_tbl 表中 runoob_id 為 3 的記錄:
MySQL DELETE 子句測試:
<?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 = 'DELETE FROM runoob_tbl
WHERE runoob_id=3';
mysqli_select_db( $conn, 'RUNOOB' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
die('無法删除資料: ' .
mysqli_error($conn));
echo '資料删除成功!';
mysqli_close($conn);
?>
MySQL UPDATE 查詢 MySQL LIKE 子句筆記清單
-
delete 語句用于删除表中的資料, 基本用法為:
delete from 表名稱 where 删除條件;
以下是在表 students 中的執行個體:
删除 id 為 3 的行: delete from students where id=3;
删除所有年齡小于 21 歲的資料: delete from students where age<20;
删除表中的所有資料: delete from students;