PHP MySQL:将数据插入表中
来源:藏色散人
发布时间:2018-11-14 09:29:44
阅读量:680
简介:在本教程中,您将学习如何使用PHP PDO将数据插入MySQL表。
推荐参考视频教程:《mysql教程》
下面我们就结合简单的例子给大家介绍。
tasks数据表内容如下:
我们要将数据插入表中,可以按照以下步骤操作:
通过创建PDO对象的新实例连接到MySQL数据库。
构造一个MySQL INSERT语句。
调用exec() PDO对象的方法。
PHP MySQL插入数据示例:在表示例中插入一个新行
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | <?php
class InsertDataDemo {
const DB_HOST = 'localhost' ;
const DB_NAME = 'classicmodels' ;
const DB_USER = 'root' ;
const DB_PASSWORD = '' ;
private $pdo = null;
public function __construct() {
$conStr = sprintf( "mysql:host=%s;dbname=%s" , self::DB_HOST, self::DB_NAME);
try {
$this ->pdo = new PDO( $conStr , self::DB_USER, self::DB_PASSWORD);
} catch (PDOException $pe ) {
die ( $pe ->getMessage());
}
}
|
以下示例说明如何在tasks表中插入新行。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
public function insert() {
$sql = "INSERT INTO tasks (
subject,
description,
start_date,
end_date
)
VALUES (
'Learn PHP MySQL Insert Dat' ,
'PHP MySQL Insert data into a table' ,
'2013-01-01' ,
'2013-01-01'
)";
return $this ->pdo-> exec ( $sql );
}
|
定义类InsertDataDemo,该构造函数建立数据库连接,并使用析构函数来关闭数据库连接。
在InsertDataDemo类中,我们定义了一个insert方法,它调用exec() PDO对象的方法来执行INSERT语句。
以下语句创建InsertDataDemo类的实例,并调用insert() 方法以将新行插入到tasks表中。
1 2 | $obj = new InsertDataDemo();
$obj ->insert();
|
让我们查询tasks表中的数据:
PHP MySQL:使用预处理语句示例插入单行
要动态且安全地将值从PHP传递到SQL语句,可以使用PDO预处理语句。
首先,使用带有命名占位符的MySQL语句,如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 | $sql = 'INSERT INTO tasks (
subject,
description,
start_date,
end_date
)
VALUES (
:subject,
:description,
:start_date,
:end_date
);';
|
:subject,:description,:startdate和:enddate称为命名占位符。
其次,调用prepare() PDO对象的方法为执行准备SQL语句:
1 | $q = $pdo ->prepare( $sql );
|
然后,调用execute() 方法并传递一个包含与命名占位符对应的值的数组。
把它们放在一起。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
function insertSingleRow( $subject , $description , $startDate , $endDate ) {
$task = array ( ':subject' => $subject ,
':description' => $description ,
':start_date' => $startDate ,
':end_date' => $endDate );
$sql = 'INSERT INTO tasks (
subject,
description,
start_date,
end_date
)
VALUES (
:subject,
:description,
:start_date,
:end_date
);';
$q = $this ->pdo->prepare( $sql );
return $q ->execute( $task );
}
|
现在我们可以将任务的数据传递给insertSingleRow()方法:
1 2 3 4 | $obj ->insertSingleRow( 'MySQL PHP Insert Tutorial' ,
'MySQL PHP Insert using prepared statement' ,
'2013-01-01' ,
'2013-01-02' );
|
检查tasks表:
PHP MySQL在表格示例中插入多行
有两种方法可以在表中插入多行:
insertSingleRow() 多次执行该方法。
构造一个INSERT插入多行并执行它的MySQL 语句。
本篇文章就是关于PHP PDO预处理语句将数据插入MySQL表的具体方法介绍,希望对需要的朋友有所帮助。