我有这个简单的代码来根据相关性制作搜索结果:
$stmt = $db->query('SELECT * FROM `apps` WHERE MATCH(appName, appSeller) AGAINST("angry")');
$appCount = $stmt->rowCount();
echo $appCount;
它没有显示任何结果!
提前感谢您的帮助,马塞尔
Stackoverflow 的可用性低于零。
因为没有办法让在 PDO 标签下发布问题的每个人都显示半屏横幅:
因为在没有错误信息的情况下询问是没有意义的,但错误信息很可能会使问题变得不必要。
$dsn = 'mysql:host=localhost;dbname=test;charset=utf8';
$opt = array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
);
$pdo = new PDO($dsn,'root','', $opt);
尝试
'SELECT * FROM `apps` WHERE MATCH(appName, appSeller) AGAINST("angry")'
在 phpmyadmin 中,看看它是否真的返回任何东西。
试试这个
<?php
// Connection data (server_address, database, name, poassword)
$hostdb = 'localhost';
$namedb = 'tests';
$userdb = 'username';
$passdb = 'password';
try {
// Connect and create the PDO object
$db = new PDO("mysql:host=$hostdb; dbname=$namedb", $userdb, $passdb);
$db->exec("SET CHARACTER SET utf8"); // Sets encoding UTF-8
// Define and perform the SQL SELECT query
$sql = "SELECT * FROM `apps` WHERE MATCH(appName, appSeller) AGAINST("angry")";
$stmt = $db->query($sql);
// If the SQL query is succesfully performed ($stmt not false)
if($stmt !== false) {
$cols = $stmt->columnCount(); // Number of returned columns
echo 'Number of returned columns: '. $cols. '<br />';
// Parse the result set
foreach($stmt as $row) {
echo $row['id']. ' - '. $row['name']. ' - '. $row['category']. ' - '. $row['link']. '<br />';
}
}
$db = null; // Disconnect
}
print_r($sth->errorInfo());
}
?>
将您的代码包含在 try 和 catch 块中,然后您应该知道您的 SQL 语法哪里出错了:
try {
// your code
} catch ( PDOException £e ) {
echo $e->getMessage();
exit();
}