我有一张桌子,我正在阅读它的n%记录.为此,我准备了一个查询:
SET @rows := (SELECT COUNT(*)*0.5 FROM trending);
PREPARE STMT FROM 'SELECT * FROM trending ORDER BY Count LIMIT ?';
EXECUTE STMT USING @rows;
我得到的输出是:
SET @rows := (SELECT COUNT(*)*0.5 FROM trending);# MySQL returned an empty result set (i.e. zero rows). PREPARE STMT FROM 'SELECT * FROM trending ORDER BY Count LIMIT ?';# MySQL returned an empty result set (i.e. zero rows). EXECUTE STMT USING @rows;# Rows: 8
我怎样才能从表中获取记录?
解决方法:
SET @rows := (SELECT COUNT(*)*0.5 FROM trending);
PREPARE STMT FROM 'SELECT * FROM trending order by somecolumn LIMIT ?';
EXECUTE STMT USING @rows;
在我的系统上工作正常.奇数行可以得到一个综合
编辑:
create table thing2
( id int auto_increment primary key,
theWhat varchar(40) not null,
`count` int not null
);
插入5行:
insert thing2(theWhat,`count`) values ('anchovies',6),('tomato',1),('cat',99),('mouse',8),('spoon',70);
SET @rows := (SELECT COUNT(*)*0.5 FROM thing2);
PREPARE STMT FROM 'SELECT * FROM thing2 LIMIT ?';
EXECUTE STMT USING @rows;
count might need to be in backticks (not on my system), if that is actually a column and you are doing
the following :
SET @rows := (SELECT COUNT(*)*0.5 FROM thing2);
PREPARE STMT FROM 'SELECT * FROM thing2 order by `count` LIMIT ?';
EXECUTE STMT USING @rows;
+----+-----------+-------+
| id | theWhat | count |
+----+-----------+-------+
| 2 | tomato | 1 |
| 1 | anchovies | 6 |
| 4 | mouse | 8 |
+----+-----------+-------+
SET @rows := (SELECT COUNT(*)*0.5 FROM thing2);
PREPARE STMT FROM 'SELECT * FROM thing2 order by theWhat LIMIT ?';
EXECUTE STMT USING @rows;
+----+-----------+-------+
| id | theWhat | count |
+----+-----------+-------+
| 1 | anchovies | 6 |
| 3 | cat | 99 |
| 4 | mouse | 8 |
+----+-----------+-------+
Revision1(显示PHP)
此修订是由于提到PHP.因此,这显示了一个多查询,使用从该查询的特定行给出的结果集.显示使用明确保留其值的@变量.并且为多查询本身设置了一个heredoc变量$theSql.
<?php
error_reporting(E_ALL);
//mysqli_report(MYSQLI_REPORT_ALL);
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
ini_set('display_errors', 1);
try {
$mysqli= new mysqli('localhost', 'dbusername', 'thePassword', 'theDbname'); // tweak accordingly
if ($mysqli->connect_error) {
die('Connect Error (' . $mysqli->connect_errno . ') '
. $mysqli->connect_error);
}
echo "I am connected and feel happy.<br/>";
// Note the 3rd statment below (the EXECUTE) and the code below it that cares about output for the 3rd one only
$theSql = <<<SQL
SET @rows := (SELECT COUNT(*)*0.5 FROM thing2);
PREPARE stmt123 FROM 'SELECT * FROM thing2 LIMIT ?';
EXECUTE stmt123 USING @rows;
DEALLOCATE PREPARE stmt123;
SQL;
$shouldDebug=false; // change to true to see more debug info (such as the skipped multi-query results)
$theCounter=0;
$weCareAbout=3; // the 3rd line of the command: "EXECUTE stmt123 USING @rows; "
if ($mysqli->multi_query($theSql)) {
do { // Note this loop poached from http://php.net/manual/en/mysqli.multi-query.php
if ($shouldDebug) echo "1a.<br/>";
$theCounter++;
// store first result set
if ($result = $mysqli->store_result()) {
if ($shouldDebug) echo "1b.<br/>";
if ($theCounter==$weCareAbout) {
while ($row = $result->fetch_row()) {
echo $row[0]." ".$row[1]." ".$row[2]."<br>";
}
}
if ($shouldDebug) echo "1c.<br/>";
$result->free();
if ($shouldDebug) echo "1d.<br/>";
}
// print divider
if ($mysqli->more_results() && $shouldDebug) {
printf("-----------------\n");
}
if ($shouldDebug) "1e.<br/>";
} while ($mysqli->next_result() && $mysqli->more_results());
// above line to avoid error: Strict Standards: mysqli::next_result(): There is no next result set. ...
// ...Please, call mysqli_more_results()/mysqli::more_results() to check whether to call ...
//
// the Manual page is not exactly clear on this. In fact, faulty.
// http://php.net/manual/en/mysqli.multi-query.php
}
$mysqli->close(); // just showing it, what the heck
} catch (mysqli_sql_exception $e) {
throw $e;
}
?>
浏览器输出:
I am connected and feel happy.
1 anchovies 6
2 tomato 1
3 cat 99
上面做的/有时间的长短是因为我们在该循环中基于传递的查询进行了4次.
请参见手册页面mysqli.multi-query
和mysqli.store-result
.
标签:php,mysql 来源: https://codeday.me/bug/20191003/1848922.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。