吳裕雄 10-MySQL插入資料
語法
以下為向MySQL資料表插入資料通用的 INSERT INTO SQL語法:
INSERT INTO table_name ( field1, field2,...fieldN )
VALUES
( value1, value2,...valueN );
如果資料是字元型,必須使用單引號或者雙引號,如:"value"。
通過命令提示視窗插入資料
以下我們將使用 SQL INSERT INTO 語句向 MySQL 資料表 runoob_tbl 插入資料
例項
以下例項中我們將向 runoob_tbl 表插入三條資料:
mysql -u root -p password;
Enter password:*******
mysql> use RUNOOB;
Database changed
INSERT INTO runoob_tbl (runoob_title, runoob_author, submission_date) VALUES ("學習 PHP", "菜鳥教程", NOW());
INSERT INTO runoob_tbl (runoob_title, runoob_author, submission_date) VALUES ("學習 PHP", "菜鳥教程", NOW());
INSERT INTO runoob_tbl (runoob_title, runoob_author, submission_date) VALUES ("學習 PHP", "菜鳥教程", NOW());
使用PHP指令碼插入資料
你可以使用PHP 的 mysqli_query() 函式來執行 SQL INSERT INTO命令來插入資料。
該函式有兩個引數,在執行成功時返回 TRUE,否則返回 FALSE。
語法
mysqli_query(connection,query,resultmode);
引數 描述
connection 必需。規定要使用的 MySQL 連線。
query 必需,規定查詢字串。
resultmode 可選。一個常量。可以是下列值中的任意一個:
MYSQLI_USE_RESULT(如果需要檢索大量資料,請使用這個)
MYSQLI_STORE_RESULT(預設)
例項
以下例項中程式接收使用者輸入的三個欄位資料,並插入資料表中:
新增資料
<?php
$dbhost = 'localhost:3306'; // mysql伺服器主機地址
$dbuser = 'root'; // mysql使用者名稱
$dbpass = '123456'; // mysql使用者名稱密碼
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('連線失敗: ' . mysqli_error($conn));
}
echo '連線成功<br />';
// 設定編碼,防止中文亂碼
mysqli_query($conn , "set names utf8");
$runoob_title = '學習 Python';
$runoob_author = 'RUNOOB.COM';
$submission_date = '2016-03-06';
$sql = "INSERT INTO runoob_tbl ".
"(runoob_title,runoob_author, submission_date) ".
"VALUES ".
"('$runoob_title','$runoob_author','$submission_date')";
mysqli_select_db( $conn, 'RUNOOB' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
die('無法插入資料: ' . mysqli_error($conn));
}
echo "資料插入成功\n";
mysqli_close($conn);
?>
INSERT 插入多條資料
INSERT INTO table_name(field1, field2,...fieldN)VALUES
(valueA1,valueA2,...valueAN),
(valueB1,valueB2,...valueBN),
(valueC1,valueC2,...valueCN);