如何查看mysql更新查询是否成功?

问题描述 投票:0回答:3
function insertNewBidPrice($code, $newBidPrice)
{
  global $conn;
  $sql = "update auctionitem set highestbid=$newBidPrice where code=$code";
  //echo $sql;
  if($conn->query($sql))
  {
    return 1;
  }
  else
  {
    require 0;
  }
}

我有这个 php 函数,尽管更新查询成功更新了表,但结果始终为 0。

我使用 PDO。

$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
php mysql pdo
3个回答
0
投票

首先使用prepare创建一个statement对象。

$stmt = $conn->prepare($sql);
$worked = $stmt->execute();
if ($worked == TRUE) {
    //I did stuff
} else {
    // nope
}

0
投票
function insertNewBidPrice($code, $newBidPrice) {
    global $conn;
    // write your query
    $sql = "UPDATE auctionitem SET highestbid='$newBidPrice' WHERE code='$code'";

    // run the query
    $result = $conn->query($sql);

    // check the result of the query
    if ($result == true) {
        // it was a success
        return 1;
    } else {
        return 0;
    }
}

global $conn;
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "my_db";

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
} else {
    // it worked
}

给你,这应该可以解决问题。我注意到你在 if else 语句中说“需要 0”,它需要返回。除此之外,我不确定你的问题,但我能想到两种可能性。

  1. 您的 $conn 变量无效。检查它是否具有正确的凭据,请参阅 $conn->connect_error 行,它位于我编写的代码中,但也在此处:http://php.net/manual/en/mysqli.connect-error.php.
  2. 可能查询不正确。就我个人而言,我用大写字母等格式化所有内容。当我这样做时,我的文本编辑器会对其进行着色,因此我很容易看出什么是什么。另外,SQL 语句中的变量周围没有引号,如果它是整数,这很好,但如果您不小心传递了字符串,它将失败。

还要检查您是否选择了正确的表格等。在你的 SQL 中。


0
投票

我面临着同样的挑战,试图知道更新是否成功,但对于 mysqli 来说,即使没有任何更新,更新也是如此。 如果您需要知道某些行是否已更新,最好的方法是使用

$mysqli->affected_rows

这将返回更新的行数,但请注意,如果您使用相同的值更新且没有错误,您将收到 0。 如果您有一个名为 value 的字段,其值为“1000”,并且您的查询是 Update table set value='1000',它将返回 0 个受影响的行,但执行查询时没有错误。

© www.soinside.com 2019 - 2024. All rights reserved.