簡體   English   中英

SQL查詢無法在PHP PDO中工作

[英]sql query not working in php pdo

返回結果:

$query = $dbh->prepare('SELECT * FROM groups WHERE id LIKE :id ORDER BY id');
$query->bindValue(':id', $this->id.'_');

這不是:

$query = $dbh->prepare('SELECT g.*, d.desc_text FROM groups g LEFT JOIN descriptions d ON d.desc_id=g.id WHERE g.id LIKE :id AND d.desc_type=1 ORDER BY g.id');
$query->bindValue(':id', $this->id.'_');

但是,如果我在WebMin中運行下面的SQL查詢(“ 0002_”是上面綁定的值),那么我會得到結果。

SELECT g.*, d.desc_text FROM groups g LEFT JOIN descriptions d ON d.desc_id=g.id WHERE g.id LIKE "0002_" AND d.desc_type=1 ORDER BY g.id

那么,為什么PDO不喜歡上面第二段代碼中的查詢?

好吧,我釘了一下:

正如我在第一個問題中所說的那樣,下面的代碼不會返回結果:

$query = $dbh->prepare('SELECT g.*, d.desc_text FROM groups g LEFT JOIN descriptions d ON d.desc_id=g.id WHERE g.id LIKE :id AND d.desc_type=1 ORDER BY g.id');
$query->bindValue(':id', $this->id.'_');

此代碼返回預期結果:

$query = $dbh->prepare('SELECT g.*, d.desc_text FROM groups g LEFT JOIN descriptions d ON d.desc_id=g.id AND d.desc_type=1 WHERE g.id LIKE :id ORDER BY g.id');
$query->bindValue(':id', $this->id.'_');

奇怪的是,從Webmin中運行時,任一SQL查詢都將返回結果,但是PHP PDO似乎不喜歡將“ AND d.desc_type = 1”作為WHERE子句的一部分,而需要在LEFT JOIN ON子句中使用它。

為什么PDO不喜歡上面第二段代碼中的查詢?

詢問PDO:

$dbh->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );

如果PDO沒有拋出任何錯誤-它“喜歡”您的查詢,並且與問題無關。 檢查您的數據,數據庫和錯別字。

作為最后的檢查,省略bindvalue部分

$stmt = $dbh->prepare('put your query from WEBMIN here');
$stmt->execute();
$res  = $stmt->fetch();
var_dump($res);

如果它刪除任何數據-責怪PDO
如果不是,請檢查您的數據,數據庫和錯別字。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM