下面我们就结合简单的例子给大家介绍。
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; /** * Open the database connection */ public function __construct() { // open database connection $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 | /** * Insert a row into a table * @return */ 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表中。 | $obj = new InsertDataDemo(); $obj->insert();
|
让我们查询tasks表中的数据: PHP MySQL:使用预处理语句示例插入单行 要动态且安全地将值从PHP传递到SQL语句,可以使用PDO预处理语句。 首先,使用带有命名占位符的MySQL语句,如下所示: | $sql = 'INSERT INTO tasks ( subject, description, start_date, end_date ) VALUES ( :subject, :description, :start_date, :end_date );';
|
:subject,:description,:startdate和:enddate称为命名占位符。 其次,调用prepare() PDO对象的方法为执行准备SQL语句: | $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 | /** * Insert a new task into the tasks table * @param string $subject * @param string $description * @param string $startDate * @param string $endDate * @return mixed returns false on failure */ 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()方法: | $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表的具体方法介绍,希望对需要的朋友有所帮助。
|