<tfoot id='mZsE5'></tfoot>
      <bdo id='mZsE5'></bdo><ul id='mZsE5'></ul>
    <legend id='mZsE5'><style id='mZsE5'><dir id='mZsE5'><q id='mZsE5'></q></dir></style></legend>
  • <i id='mZsE5'><tr id='mZsE5'><dt id='mZsE5'><q id='mZsE5'><span id='mZsE5'><b id='mZsE5'><form id='mZsE5'><ins id='mZsE5'></ins><ul id='mZsE5'></ul><sub id='mZsE5'></sub></form><legend id='mZsE5'></legend><bdo id='mZsE5'><pre id='mZsE5'><center id='mZsE5'></center></pre></bdo></b><th id='mZsE5'></th></span></q></dt></tr></i><div id='mZsE5'><tfoot id='mZsE5'></tfoot><dl id='mZsE5'><fieldset id='mZsE5'></fieldset></dl></div>

      <small id='mZsE5'></small><noframes id='mZsE5'>

        带 PDO 的多个刀片

        时间:2023-10-04
          <tbody id='4BZEk'></tbody>

                <legend id='4BZEk'><style id='4BZEk'><dir id='4BZEk'><q id='4BZEk'></q></dir></style></legend>
                  <bdo id='4BZEk'></bdo><ul id='4BZEk'></ul>

                • <tfoot id='4BZEk'></tfoot>
                  <i id='4BZEk'><tr id='4BZEk'><dt id='4BZEk'><q id='4BZEk'><span id='4BZEk'><b id='4BZEk'><form id='4BZEk'><ins id='4BZEk'></ins><ul id='4BZEk'></ul><sub id='4BZEk'></sub></form><legend id='4BZEk'></legend><bdo id='4BZEk'><pre id='4BZEk'><center id='4BZEk'></center></pre></bdo></b><th id='4BZEk'></th></span></q></dt></tr></i><div id='4BZEk'><tfoot id='4BZEk'></tfoot><dl id='4BZEk'><fieldset id='4BZEk'></fieldset></dl></div>

                  <small id='4BZEk'></small><noframes id='4BZEk'>

                  本文介绍了带 PDO 的多个刀片的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  我有数据库表:imagescategory

                  目前唯一插入到类别表的函数是这样的:

                  Currently the only function to insert in category table is similar to this:

                  public function add($ttitle)
                  {      
                  try
                      {
                          $stmt = $this->db->prepare("INSERT INTO category (title) VALUES(:title)");
                          $stmt->bindparam(":title",$ttitle);                 
                          $stmt->execute();
                          return true;
                  
                      }
                      catch(PDOException $e)
                      {
                          echo $e->getMessage();  
                          return false;
                      }
                  
                  }
                  

                  我有一个表格可以输入标题和插入网址图片的可能性.

                  I have a form to enter title and the possibility of inserting urls images.

                  通过单击提交标题,我想转到类别表,到目前为止还可以,图像应该转到表图像,每个图像都有一个 id,但内部连接到类别的 id.

                  By clicking on the submit the title I want to go to the category table, so far ok, images should go to the table images, an id for each image but with inner join to the id of the category.

                  表格images:

                  id_image | category_id | dir_image
                  

                  我无法正确执行此操作

                  $stmt = $this->db->prepare("INSERT INTO category (title) VALUES(:ttitle)");
                  
                  $stmt = $this->db->prepare("SELECT id_image FROM images WHERE id_category = category_id ");
                  

                  我想要的结果示例:

                  html 表单

                  Category title: Test
                  Image1:   image1.png
                  Image2:   image2.png
                  Image3:   image3.png
                  Image4:   image4.png
                                Submit
                  

                  提交后

                  表格类别:

                   id_category | title
                      1          Test
                  

                  表格图片:

                   id_image | category_id | dir_image
                      1            1         image1.png
                      2            1         image2.png
                      3            1         image3.png
                      4            1         image4.png
                  

                  <小时>

                  更新:

                  public function add($ttitle,$images)
                  {
                  try {
                          $stmt = $this->db->prepare("INSERT INTO category (title) VALUES(:title)");
                          $stmt->bindparam(":title",$ttitle);                    
                          $stmt->execute();
                  
                          $lastId = $db->lastInsertId();
                  
                         $imgs = count($images);
                         for ($i = 0; $i < $imgs; $i++){
                  
                         $stmt = $this->db->prepare("INSERT INTO images (category_id, dir_image) VALUES (:title)");
                          $stmt->bindparam(":category_id",$lastId); 
                          $stmt->bindparam(":dir_image",$images);
                          $stmt = $this->db->prepare($sql);
                          $stmt->execute()
                  
                          } 
                  
                  
                  
                          return true;
                      }
                      catch(PDOException $e) {
                          echo $e->getMessage();    
                          return false;
                      }
                  
                  }
                  

                  推荐答案

                  几件事:

                  1. 删除for循环中的第二个prepare语句
                  2. 在sql语句的VALUES()中添加绑定参数
                  3. 使用 for 循环迭代器或使用 foreach
                  4. 索引 $images 数组
                  1. Remove the second prepare statement inside for loop
                  2. Add binded params into the VALUES() of sql statement
                  3. Index the $images array with for loop iterator or use foreach

                  查看调整后的for循环:

                  $stmt = $this->db->prepare("INSERT INTO images (category_id, dir_image) 
                                              VALUES (:category_id, :dir_image)");
                  
                  $stmt->bindParam(":category_id" ,$lastId); 
                  $stmt->bindParam(":dir_image", $image);
                  for ($i = 0; $i < count($images); $i++){
                      $image = $images[$i];
                      $stmt->execute();
                  } 
                  

                  或者使用 foreach 循环 (假设是一维数组):

                  $stmt = $this->db->prepare("INSERT INTO images (category_id, dir_image) 
                                              VALUES (:category_id, :dir_image)");
                  
                  $stmt->bindParam(":category_id", $lastId); 
                  $stmt->bindParam(":dir_image", $item);
                  foreach ($images as $item){
                      $stmt->execute();
                  } 
                  

                  这篇关于带 PDO 的多个刀片的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:PDO UTF-8 编码问题? 下一篇:如何检查邮箱是否已经注册?

                  相关文章

                  最新文章

                  <i id='9EYtM'><tr id='9EYtM'><dt id='9EYtM'><q id='9EYtM'><span id='9EYtM'><b id='9EYtM'><form id='9EYtM'><ins id='9EYtM'></ins><ul id='9EYtM'></ul><sub id='9EYtM'></sub></form><legend id='9EYtM'></legend><bdo id='9EYtM'><pre id='9EYtM'><center id='9EYtM'></center></pre></bdo></b><th id='9EYtM'></th></span></q></dt></tr></i><div id='9EYtM'><tfoot id='9EYtM'></tfoot><dl id='9EYtM'><fieldset id='9EYtM'></fieldset></dl></div>
                  <legend id='9EYtM'><style id='9EYtM'><dir id='9EYtM'><q id='9EYtM'></q></dir></style></legend>

                    • <bdo id='9EYtM'></bdo><ul id='9EYtM'></ul>

                      <small id='9EYtM'></small><noframes id='9EYtM'>

                      <tfoot id='9EYtM'></tfoot>