黑马程序员技术交流社区

标题: 【上海校区】PHP MySQL:将数据插入表中  [打印本页]

作者: 梦缠绕的时候    时间: 2018-11-9 09:47
标题: 【上海校区】PHP 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;
  
    /**
     * 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表中。
1
2
$obj = new InsertDataDemo();
$obj->insert();

让我们查询tasks表中的数据:
1
2
SELECT *
  FROM 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
$q->execute($task)

把它们放在一起。
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()方法:
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表的具体方法介绍,希望对需要的朋友有所帮助。


作者: 不二晨    时间: 2018-11-14 15:27
~(。≧3≦)ノ⌒☆
作者: 魔都黑马少年梦    时间: 2018-11-15 16:36





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2