久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

  • <tfoot id='XYq9D'></tfoot>
      <bdo id='XYq9D'></bdo><ul id='XYq9D'></ul>
    <legend id='XYq9D'><style id='XYq9D'><dir id='XYq9D'><q id='XYq9D'></q></dir></style></legend>

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

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

      1. PHP、MySQL、PDO - 從 UPDATE 查詢中獲取結(jié)果?

        PHP, MySQL, PDO - Get result from UPDATE query?(PHP、MySQL、PDO - 從 UPDATE 查詢中獲取結(jié)果?)

      2. <small id='YMdzE'></small><noframes id='YMdzE'>

        <i id='YMdzE'><tr id='YMdzE'><dt id='YMdzE'><q id='YMdzE'><span id='YMdzE'><b id='YMdzE'><form id='YMdzE'><ins id='YMdzE'></ins><ul id='YMdzE'></ul><sub id='YMdzE'></sub></form><legend id='YMdzE'></legend><bdo id='YMdzE'><pre id='YMdzE'><center id='YMdzE'></center></pre></bdo></b><th id='YMdzE'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='YMdzE'><tfoot id='YMdzE'></tfoot><dl id='YMdzE'><fieldset id='YMdzE'></fieldset></dl></div>

          <tfoot id='YMdzE'></tfoot>

            <legend id='YMdzE'><style id='YMdzE'><dir id='YMdzE'><q id='YMdzE'></q></dir></style></legend>
              <tbody id='YMdzE'></tbody>

              <bdo id='YMdzE'></bdo><ul id='YMdzE'></ul>
                  本文介紹了PHP、MySQL、PDO - 從 UPDATE 查詢中獲取結(jié)果?的處理方法,對(duì)大家解決問題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!

                  問題描述

                  我正在更新表中的一行,并嘗試按照 這個(gè)答案.

                  I am updating a row in a table, and trying to return the updated row, as per this SO answer.

                  我的代碼如下:

                  $sql = "SET @update_id := '';
                          UPDATE testing SET status='1', id=(SELECT @update_id:=id)
                          WHERE status='0' LIMIT 1; 
                          SELECT @update_id;";
                  
                  $db->beginTransaction();
                  try{
                      $stmt = $db->prepare($sql);
                      $stmt->execute();
                  
                      echo count($stmt->fetchAll());
                  
                      $db->commit();
                  }catch(Exception $e){
                      echo $e->getMessage();
                      exit();
                  }
                  

                  但我總是收到以下錯(cuò)誤

                  SQLSTATE[HY000]:一般錯(cuò)誤

                  SQLSTATE[HY000]: General error

                  根據(jù) $stmt->fetchAll()-general-error-when-updating-database?#answer-12980031">這個(gè)答案.如果我去掉那行,該行會(huì)適當(dāng)更新.

                  Which seems to be due to the $stmt->fetchAll(), according to this SO answer. If I take that line out, the row is updated appropriately.

                  那么,如何使用 PDO 運(yùn)行多查詢語句(多語句查詢!?),并從 SELECT 中獲取結(jié)果?

                  So, how do I run the multi-query statement (multi-statement query!?) using PDO, and obtain the results from the SELECT?

                  編輯 1

                  不需要需要更新行的計(jì)數(shù).我需要該行的實(shí)際 ID.

                  I DO NOT need the count of the rows updated. I need the actual ID of the row.

                  表架構(gòu)

                    id   |   someCol  |  status
                   ----- |   -------  |  ------
                     1   |     123    |    0
                     2   |     456    |    0
                     3   |     789    |    0
                     4   |     012    |    0
                  

                  • 看看桌子,
                  • 找到第一個(gè)狀態(tài)=0,
                  • 更新行,
                  • 返回更新行的id
                  • 我對(duì)計(jì)數(shù)的興趣為零,因?yàn)椴樵円褜?LIMIT 1 硬編碼到其中.

                    The count is of zero interest to me, as the query has LIMIT 1 hard-coded into it.

                    直線的整個(gè)點(diǎn)

                    count($stmt->fetchAll());
                    

                    是通過/失敗條件.

                    if(count ==1){
                        ... do something with the returned id ...
                    }else{
                        ... do something else ...
                    }
                    

                    編輯 2

                    顯然,這個(gè)問題很容易通過兩個(gè)單獨(dú)的查詢來解決.我更愿意在一個(gè)查詢中使用它.既是一種偏好,也是學(xué)習(xí)的機(jī)會(huì).

                    Obviously this issue is simple to get around with two separate queries. I would prefer to have this in one single query. Both a preference, as well as an opportunity to learn.

                    推薦答案

                    您需要將 SELECT @update_id 作為單獨(dú)的查詢進(jìn)行 -- 您不能將多個(gè)查詢放在一個(gè)語句中.這樣做:

                    You need to do the SELECT @update_id as a separate query -- you can't put multiple queries in a single statement. So do:

                    $sql = "SET @update_id := '';
                            UPDATE testing SET status='1', id=(SELECT @update_id:=id)
                            WHERE status='0' LIMIT 1";
                    try{
                        $db->beginTransaction();
                        $db->query($sql); // no need for prepare/execute since there are no parameters
                        $stmt = $db->query("SELECT @update_id");
                        $row = $stmt->fetch(PDO::FETCH_ASSOC);
                        $id = $row['@update_id'];
                        $db->commit();
                    } catch (Exception $e) {
                        echo $e->getMessage();
                        $db->rollBack();
                        exit();
                    }
                    

                    這篇關(guān)于PHP、MySQL、PDO - 從 UPDATE 查詢中獲取結(jié)果?的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

                    【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請(qǐng)聯(lián)系我們刪除處理,感謝您的支持!

                  相關(guān)文檔推薦

                  Deadlock exception code for PHP, MySQL PDOException?(PHP、MySQL PDOException 的死鎖異常代碼?)
                  PHP PDO MySQL scrollable cursor doesn#39;t work(PHP PDO MySQL 可滾動(dòng)游標(biāo)不起作用)
                  PHP PDO ODBC connection(PHP PDO ODBC 連接)
                  Using PDO::FETCH_CLASS with Magic Methods(使用 PDO::FETCH_CLASS 和魔術(shù)方法)
                  php pdo get only one value from mysql; value that equals to variable(php pdo 只從 mysql 獲取一個(gè)值;等于變量的值)
                  MSSQL PDO could not find driver(MSSQL PDO 找不到驅(qū)動(dòng)程序)
                  <legend id='mBESr'><style id='mBESr'><dir id='mBESr'><q id='mBESr'></q></dir></style></legend>

                    • <bdo id='mBESr'></bdo><ul id='mBESr'></ul>

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

                          <tfoot id='mBESr'></tfoot>
                            <tbody id='mBESr'></tbody>
                        • <i id='mBESr'><tr id='mBESr'><dt id='mBESr'><q id='mBESr'><span id='mBESr'><b id='mBESr'><form id='mBESr'><ins id='mBESr'></ins><ul id='mBESr'></ul><sub id='mBESr'></sub></form><legend id='mBESr'></legend><bdo id='mBESr'><pre id='mBESr'><center id='mBESr'></center></pre></bdo></b><th id='mBESr'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='mBESr'><tfoot id='mBESr'></tfoot><dl id='mBESr'><fieldset id='mBESr'></fieldset></dl></div>
                          1. 主站蜘蛛池模板: 亚洲人成网站777色婷婷 | 精品久久99| 黄色大片免费网站 | 国产高清精品一区二区三区 | 亚洲精品久久久久中文字幕欢迎你 | 一区欧美 | 草b视频 | 日韩欧美国产成人一区二区 | 久久精品成人一区 | 日韩欧美精品在线 | 精品久久久久久久久久 | 久久久久一区二区 | 午夜男人免费视频 | 国产精品成人在线观看 | 日韩精品免费在线观看 | 日本理论片好看理论片 | 欧美日韩国产高清视频 | 久久国产精彩视频 | 天天躁日日躁狠狠躁2018小说 | 一级黄在线观看 | av在线免费观看网址 | 国产夜恋视频在线观看 | 日韩一区二区三区在线视频 | 在线中文字幕日韩 | 91视频在线观看 | 国产成人精品一区二 | 日本亚洲一区二区 | 激情久久网 | 亚洲欧美综合精品久久成人 | 国内精品久久久久久久影视简单 | 狠狠干天天干 | 欧美综合一区二区 | 亚洲成人av | 亚洲国产69 | 精品福利视频一区二区三区 | 久久蜜桃av一区二区天堂 | 日韩一二区 | 国产在线97 | 日韩一二区 | 精品一区在线免费观看 | 三级高清|