Heim  >  Artikel  >  Backend-Entwicklung  >  PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

WBOY
WBOYOriginal
2021-10-28 12:05:324050Durchsuche

Im vorherigen Artikel habe ich Ihnen „Wie verwende ich PDO zum Herstellen einer Verbindung zur Datenbank beim PHP-Datenbanklernen?“ vorgestellt. 》, das Ihnen eine detaillierte Einführung in die Herstellung einer Verbindung zur Datenbank über PDO in PHP gibt. In diesem Artikel werden wir uns weiterhin mit der Verwendung von PDO zum Ausführen von SQL-Anweisungen in PHP befassen. Hoffe, es hilft allen!

PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

Im vorherigen Artikel haben wir erfahren, wie PHP über PDO eine Verbindung zur Datenbank herstellt. Um eine Verbindung zur Datenbank herzustellen, müssen Sie SQL-Anweisungen ausführen. In PDO können wir drei Möglichkeiten zum Ausführen von SQL-Anweisungen verwenden, nämlich die Methode exec() , die Methode query() und die vorbereitete Anweisung Prepare( ). - und execute()-Methoden. Dann lasst uns gemeinsam einen Blick darauf werfen. exec() 方法,query() 方法,以及预处理语句 prepare()execute() 方法。那接下来我们一起来看一下吧。

<strong><span style="font-size: 20px;">exec() </span></strong>方法

在我们执行 INSERT、UPDATE 和 DELETE 等这些不需要返回结果集的SQL语句的时候,我们就可以使用PDO对象中的 exec() 方法,使用这种方法成功执行之后,返回的结果是受到影响的行数,

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

PDO::exec(string $sql)

要注意的是:

  • $sql 为要执行的 SQL 语句。

  • exec() 方法不会从 SELECT 查询语句中获取相应的结果。

那接下来我们通过实例尝试向数据库中加入一条数据,示例如下:

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

输出结果:

PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

由上述示例可以看出,我们通过exec()方法成功的向数据库中加入了一条数据,并且返回的结果是收到影响的行数。想要返回一个对象的话就可以通过query() 方法,接下来我们看另一种执行SQL语句的方式:query() 方法。

<strong><span style="font-size: 20px;">query() </span></strong>方法

在上述事例中通过exec()方法能够返回这些不需要返回结果集的语句信息,当执行需要返回结果集的 SELECT 查询语句时,我们就需要通过query()语句。通过该方法执行成功的话,反悔的家国是一个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 为要执行的 SQL 语句;其余的参数用来为语句设置默认的获取模式,相当于调用结果对象 PDOStatement::setFetchMode() 方法。

那接下来我们通过query()方法来查询我们前面添加的那条数据,示例如下:

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

输出结果:

PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

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

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

  • query() 可以实现所有 exec() 的功能;

  • 当把 select 语句应用到 exec() 时,总是返回 0;

  • 如果要看查询的具体结果,可以通过 foreach 语句完成循环输出。

<strong><span style="font-size: 20px;">prepare()</span></strong>execute() 方法

当有需要迭代传入不同参数的时候,也就是方同一个查询需要多次执行的时候,使用预处理语句的方式会让实现效率更高,使用预处理语句就需要用到PDO对象中的 prepare() 方法去准备一个将要执行的查询,再使用 PDOStatement 对象中的 execute() 方法来执行。那接下来我们就来看一下prepare() execute() 方法。

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

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

其中需要注意的是:

  • $statement   表示的是必须是对目标数据库有效的 SQL 语句模板;

  • $driver_options

    <strong><span style="font-size: 20px;">exec() </span></strong>Methode
Wenn wir INSERT, UPDATE und DELETE und andere SQL-Anweisungen ausführen, die keine Ergebnismenge zurückgeben müssen, können wir exec() im PDO-Objekt verwenden code>-Methode. Nach erfolgreicher Ausführung mit dieser Methode ist das zurückgegebene Ergebnis die Anzahl der betroffenen Zeilen.<br>Das Syntaxformat der <p></p>exec()-Methode lautet wie folgt: <p><pre class="brush:php;toolbar:false">PDOStatement::execute([array $input_parameters])</pre></p>Es ist zu beachten, dass: 🎜 <ul style="list-style-type: disc;"> <li>🎜<code>$sql ist die auszuführende SQL-Anweisung. Die Methode 🎜🎜
  • 🎜exec() erhält nicht die entsprechenden Ergebnisse aus der SELECT-Abfrageanweisung. 🎜🎜🎜🎜Dann versuchen wir, anhand eines Beispiels ein Datenelement zur Datenbank hinzuzufügen. Das Beispiel lautet wie folgt:
    🎜
    <?php
        $dsn  = &#39;mysql:host=127.0.0.1;dbname=test&#39;;
        $user = &#39;root&#39;;
        $pwd  = &#39;root&#39;;
        try{
            $pdo = new PDO($dsn,$user,$pwd);
            $sql = "SELECT name,age,sex FROM user WHERE age = :age";
            $sth = $pdo -> prepare($sql);
            $sth -> execute([&#39;:age&#39;=>11]);
            $res1 = $sth -> fetchAll();
            $sth -> execute(array(&#39;:age&#39;=>14));
            $res2 = $sth -> fetchAll();
            echo &#39;<pre class="brush:php;toolbar:false">&#39;;
            print_r($res1);
            print_r($res2);
        }catch(PDOException $e){
            echo &#39;数据库连接失败:&#39;.$e -> getMessage();
        }
    ?>
    🎜Ausgabeergebnis:
    🎜🎜PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?🎜🎜Wie aus dem obigen Beispiel ersichtlich ist, haben wir es geschafft übergeben Sie die Methode exec() an Ein Datenelement wird zur Datenbank hinzugefügt und das zurückgegebene Ergebnis ist die Anzahl der betroffenen Zeilen. Wenn Sie ein Objekt zurückgeben möchten, können Sie die Methode query() verwenden. Schauen wir uns als Nächstes eine andere Möglichkeit zum Ausführen von SQL-Anweisungen an: die Methode query(). 🎜🎜<strong><span style="max-width:90%">query() </span></strong>Methode🎜🎜Im obigen Beispiel kann die Methode exec() die Anweisungsinformationen zurückgeben, die keinen Ergebnissatz zurückgeben müssen. Beim Ausführen einer SELECT-Abfrage Das muss eine Ergebnismenge zurückgeben, eine Anweisung. Wir müssen die query()-Anweisung übergeben. Wenn diese Methode erfolgreich ausgeführt wird, ist das reuige Land ein PDOStatement-Objekt.
    🎜🎜Wenn Sie die Methode query() verwenden und die Gesamtzahl der erhaltenen Datenzeilen wissen möchten, können Sie sie mit der Methode rowCount() im PDOStatement-Objekt abrufen. Das Syntaxformat der 🎜🎜query()-Methode lautet wie folgt:
    🎜
    <?php
        $dsn  = &#39;mysql:host=127.0.0.1;dbname=test&#39;;
        $user = &#39;root&#39;;
        $pwd  = &#39;root&#39;;
        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,&#39;男&#39;]);
            $res1 = $sth -> fetchAll();
            $sth -> execute(array(11,&#39;女&#39;));
            $res2 = $sth -> fetchAll();
            echo &#39;<pre class="brush:php;toolbar:false">&#39;;
            print_r($res1);
            print_r($res2);
        }catch(PDOException $e){
            echo &#39;数据库连接失败:&#39;.$e -> getMessage();
        }
    ?>
    🎜Es ist zu beachten, dass:
    🎜🎜$sql die auszuführende SQL-Anweisung ist ; Die restlichen Parameter sind: Um den Standard-Abrufmodus für die Anweisung festzulegen, entspricht dies dem Aufruf der Methode PDOStatement::setFetchMode() des Ergebnisobjekts. 🎜🎜Dann verwenden wir die Methode query(), um die zuvor hinzugefügten Daten abzufragen. Das Beispiel lautet wie folgt:
    🎜rrreee🎜Ausgabeergebnis:
    🎜🎜PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?🎜🎜welches query() und verwendet Bei der Methode exec() sind die folgenden Punkte zu beachten: 🎜
    • Sowohl query() als auch exec() können alle SQL-Anweisungen ausführen Anweisungen haben nur unterschiedliche Rückgabewerte; 🎜🎜
    • 🎜query() kann alle Funktionen von exec() realisieren; 🎜🎜
    • 🎜Wenn die select-Anweisung auf exec() angewendet wird, gibt sie immer 0 zurück;
    • 🎜Wenn Sie die spezifischen Ergebnisse der Abfrage sehen möchten, können Sie die Schleifenausgabe über die foreach-Anweisung abschließen. 🎜🎜🎜🎜<strong><span style="font-size: 20px;">prepare()</span></strong> und execute()-Methode🎜🎜Wenn es notwendig ist, verschiedene Parameter iterativ zu übergeben, d. h. wenn dieselbe Abfrage mehrmals ausgeführt werden muss , Durch die Verwendung vorbereiteter Anweisungen wird die Implementierung effizienter. Sie müssen die Methode prepare() im PDO-Objekt verwenden, um eine auszuführende Abfrage vorzubereiten, und dann den prepare()-Methode im PDOStatement-Objekt zur Ausführung. Dann werfen wir einen Blick auf die Methoden prepare() und execute() . Das Syntaxformat der 🎜🎜prepare()-Methode lautet wie folgt: 🎜rrreee🎜Es ist zu beachten, dass: 🎜
      • 🎜$statement bedeutet, dass es sich um eine SQL-Anweisungsvorlage handeln muss, die für die Zieldatenbank gültig ist; 🎜🎜<li>🎜<code>$driver_options stellt einen optionalen Parameter dar, der ein optionaler Parameter vom Array-Typ ist und ein oder enthält Weitere Schlüssel-Wert-Paare legen Eigenschaften für das zurückgegebene PDOStatement-Objekt fest. Das Syntaxformat der Methode 🎜🎜🎜🎜execute() lautet wie folgt: 🎜rrreee🎜Was zu beachten ist: 🎜
        • 参数 $input_parameters 为一个元素个数和将被执行的 SQL 语句中绑定的参数一样多的数组。

        • SQL 语句模板中可以包含零个或多个参数占位标记,格式可以是命名(:name)或问号(?)的形式,当它执行时将用真实数据取代。

        • 在同一个 SQL 语句里,命名和问号形式不能同时使用,只能选择其中一种参数形式。如果使用命名形式的占位标记,那么标记的命名必须是唯一的。

        接下来我们看一下使用命名形式的参数占位符,查询指定的 SQL 语句,示例如下:

        <?php
            $dsn  = &#39;mysql:host=127.0.0.1;dbname=test&#39;;
            $user = &#39;root&#39;;
            $pwd  = &#39;root&#39;;
            try{
                $pdo = new PDO($dsn,$user,$pwd);
                $sql = "SELECT name,age,sex FROM user WHERE age = :age";
                $sth = $pdo -> prepare($sql);
                $sth -> execute([&#39;:age&#39;=>11]);
                $res1 = $sth -> fetchAll();
                $sth -> execute(array(&#39;:age&#39;=>14));
                $res2 = $sth -> fetchAll();
                echo &#39;<pre class="brush:php;toolbar:false">&#39;;
                print_r($res1);
                print_r($res2);
            }catch(PDOException $e){
                echo &#39;数据库连接失败:&#39;.$e -> getMessage();
            }
        ?>

        输出结果:

        PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

        上述示例是使用命名形式的参数占位符,查询指定的 SQL 语句,接下来我们看一下使用问号形式的参数占位符,查询指定的 SQL 语句。示例如下:

        <?php
            $dsn  = &#39;mysql:host=127.0.0.1;dbname=test&#39;;
            $user = &#39;root&#39;;
            $pwd  = &#39;root&#39;;
            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,&#39;男&#39;]);
                $res1 = $sth -> fetchAll();
                $sth -> execute(array(11,&#39;女&#39;));
                $res2 = $sth -> fetchAll();
                echo &#39;<pre class="brush:php;toolbar:false">&#39;;
                print_r($res1);
                print_r($res2);
            }catch(PDOException $e){
                echo &#39;数据库连接失败:&#39;.$e -> getMessage();
            }
        ?>

        输出结果:

        PHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?

        由此我们便通过使用问号形式的参数占位符,查询指定的 SQL 语句。

        大家如果感兴趣的话,可以点击《PHP视频教程》进行更多关于PHP知识的学习。

  • Das obige ist der detaillierte Inhalt vonPHP-Datenbanklernen: Wie verwende ich PDO zum Ausführen von SQL-Anweisungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn