PHP MySQL:将数据插入表中

来源:藏色散人 发布时间:2018-11-14 09:29:44 阅读量:680

简介:在本教程中,您将学习如何使用PHP PDO将数据插入MySQL表。

推荐参考视频教程:《mysql教程

下面我们就结合简单的例子给大家介绍。

tasks数据表内容如下:

tasks-table (1).png

我们要将数据插入表中,可以按照以下步骤操作:

通过创建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;

le.png

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表:

e.png

PHP MySQL在表格示例中插入多行

有两种方法可以在表中插入多行:

insertSingleRow() 多次执行该方法。

构造一个INSERT插入多行并执行它的MySQL 语句。

本篇文章就是关于PHP PDO预处理语句将数据插入MySQL表的具体方法介绍,希望对需要的朋友有所帮助。


标签: PHP
分享:
评论:
你还没有登录,请先