溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

發(fā)布時間:2021-10-28 13:30:29 來源:億速云 閱讀:148 作者:iii 欄目:編程語言

這篇文章主要講解了“PHP數據庫學習之如何使用PDO執(zhí)行SQL語句”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“PHP數據庫學習之如何使用PDO執(zhí)行SQL語句”吧!

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

exec() 方法

在我們執(zhí)行 INSERT、UPDATE 和 DELETE 等這些不需要返回結果集的SQL語句的時候,我們就可以使用PDO對象中的 exec() 方法,使用這種方法成功執(zhí)行之后,返回的結果是受到影響的行數,

exec() 方法的語法格式如下:

PDO::exec(string $sql)

要注意的是:

  • $sql 為要執(zhí)行的 SQL 語句。

  • exec() 方法不會從 SELECT 查詢語句中獲取相應的結果。

那接下來我們通過實例嘗試向數據庫中加入一條數據,示例如下:

<?php
    $dsn  = 'mysql:host=127.0.0.1;dbname=test';
    $user = 'root';
    $pwd  = 'root';
    try{
        $pdo = new PDO($dsn,$user,$pwd);
        $sql = "insert into user(name,age,sex) values('壹壹','21','男')";
        $res = $pdo -> exec($sql);
        if($res) echo '成功添加 '.$res.' 條數據!';
    }catch(PDOException $e){
        echo '數據庫連接失?。?#39;.$e -> getMessage();
    }
?>

輸出結果:

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

由上述示例可以看出,我們通過exec()方法成功的向數據庫中加入了一條數據,并且返回的結果是收到影響的行數。想要返回一個對象的話就可以通過query() 方法,接下來我們看另一種執(zhí)行SQL語句的方式:query() 方法。

query() 方法

在上述事例中通過exec()方法能夠返回這些不需要返回結果集的語句信息,當執(zhí)行需要返回結果集的 SELECT 查詢語句時,我們就需要通過query()語句。通過該方法執(zhí)行成功的話,反悔的家國是一個PDOStatement 對象。

如果使用了query() 方法,并想了解獲取的數據行總數,可以使用 PDOStatement 對象中的 rowCount() 方法獲取。

query()方法的語法格式如下:

PDO::query(string $sql)
PDO::query(string $sql, int $PDO::FETCH_COLUMN, int $colno)
PDO::query(string $sql, int $PDO::FETCH_CLASS, string $classname, array $ctorargs)
PDO::query(string $sql, int $PDO::FETCH_INTO, object $object)

其中需要注意的是:

$sql 為要執(zhí)行的 SQL 語句;其余的參數用來為語句設置默認的獲取模式,相當于調用結果對象 PDOStatement::setFetchMode() 方法。

那接下來我們通過query()方法來查詢我們前面添加的那條數據,示例如下:

<?php
    $dsn  = 'mysql:host=127.0.0.1;dbname=test';
    $user = 'root';
    $pwd  = 'root';
    try{
        $pdo = new PDO($dsn,$user,$pwd);
        $sql = "SELECT * FROM user WHERE name='壹壹'";
        $res = $pdo -> query($sql,PDO::FETCH_ASSOC);
        print_r($res);
    }catch(PDOException $e){
        echo '數據庫連接失?。?#39;.$e -> getMessage();
    }
?>

輸出結果:

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

其中使用 query() exec() 方法有以下幾點需要注意:

  • query() 和 exec() 都可以執(zhí)行所有的 SQL 語句,只是返回值不同而已;

  • query() 可以實現所有 exec() 的功能;

  • 當把 select 語句應用到 exec() 時,總是返回 0;

  • 如果要看查詢的具體結果,可以通過 foreach 語句完成循環(huán)輸出。

prepare()execute() 方法

當有需要迭代傳入不同參數的時候,也就是方同一個查詢需要多次執(zhí)行的時候,使用預處理語句的方式會讓實現效率更高,使用預處理語句就需要用到PDO對象中的 prepare() 方法去準備一個將要執(zhí)行的查詢,再使用 PDOStatement 對象中的 execute() 方法來執(zhí)行。那接下來我們就來看一下prepare() execute() 方法。

prepare() 方法的語法格式如下:

PDO::prepare(string $statement[, array $driver_options = array()])

其中需要注意的是:

  • $statement   表示的是必須是對目標數據庫有效的 SQL 語句模板;

  • $driver_options   表示為可選參數,是數組類型的可選參數,包含一個或多個鍵值對,為返回的 PDOStatement 對象設置屬性。

execute() 方法的語法格式如下:

PDOStatement::execute([array $input_parameters])

其中需要注意的是:

  • 參數 $input_parameters 為一個元素個數和將被執(zhí)行的 SQL 語句中綁定的參數一樣多的數組。

  • SQL 語句模板中可以包含零個或多個參數占位標記,格式可以是命名(:name)或問號(?)的形式,當它執(zhí)行時將用真實數據取代。

  • 在同一個 SQL 語句里,命名和問號形式不能同時使用,只能選擇其中一種參數形式。如果使用命名形式的占位標記,那么標記的命名必須是唯一的。

接下來我們看一下使用命名形式的參數占位符,查詢指定的 SQL 語句,示例如下:

<?php
    $dsn  = 'mysql:host=127.0.0.1;dbname=test';
    $user = 'root';
    $pwd  = 'root';
    try{
        $pdo = new PDO($dsn,$user,$pwd);
        $sql = "SELECT name,age,sex FROM user WHERE age = :age";
        $sth = $pdo -> prepare($sql);
        $sth -> execute([':age'=>11]);
        $res1 = $sth -> fetchAll();
        $sth -> execute(array(':age'=>14));
        $res2 = $sth -> fetchAll();
        echo '<pre>';
        print_r($res1);
        print_r($res2);
    }catch(PDOException $e){
        echo '數據庫連接失?。?#39;.$e -> getMessage();
    }
?>

輸出結果:

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

上述示例是使用命名形式的參數占位符,查詢指定的 SQL 語句,接下來我們看一下使用問號形式的參數占位符,查詢指定的 SQL 語句。示例如下:

<?php
    $dsn  = 'mysql:host=127.0.0.1;dbname=test';
    $user = 'root';
    $pwd  = 'root';
    try{
        $pdo = new PDO($dsn,$user,$pwd);
        $sql = "SELECT name,age,sex FROM user WHERE age = ? AND sex = ?";
        $sth = $pdo -> prepare($sql);
        $sth -> execute([12,'男']);
        $res1 = $sth -> fetchAll();
        $sth -> execute(array(11,'女'));
        $res2 = $sth -> fetchAll();
        echo '<pre>';
        print_r($res1);
        print_r($res2);
    }catch(PDOException $e){
        echo '數據庫連接失?。?#39;.$e -> getMessage();
    }
?>

輸出結果:

PHP數據庫學習之如何使用PDO執(zhí)行SQL語句

由此我們便通過使用問號形式的參數占位符,查詢指定的 SQL 語句。

感謝各位的閱讀,以上就是“PHP數據庫學習之如何使用PDO執(zhí)行SQL語句”的內容了,經過本文的學習后,相信大家對PHP數據庫學習之如何使用PDO執(zhí)行SQL語句這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI