php - SQL 使用 PDO 获取单个标量

标签 php mysql sql database pdo

这个问题更多关于this post .所以我想检索某个列中的数字。假设表格如下所示:

A | B | C | D | E | F
---------------------
0 | 50| 0 | 0 | 0 | 0

假设用户在 B 中输入,我想获取表中的当前数字,即 50。这是我的 SQL 代码:

$link = new PDO('**;dbname=**;charset=UTF-8','**','**');
$stmt = $link->prepare("SELECT MAX(:type) as max FROM table");
$stmt->bindParam(':type', $type);
$stmt->execute();
$used = $stmt->fetch(PDO::FETCH_ASSOC);
$used = $used["max"];

但这只是返回 B 而不是数字。如何更改我的代码以获取号码?谢谢

最佳答案

SELECT MAX(:type) as max FROM table

假设 :type 设置为“B”,这将执行为:

SELECT MAX("B") as max FROM table

只有一个值的事物的 MAX 将是那个值,即:

SELECT "B" as max FROM table

很可能您想从该列中选择 MAX,而不是字符串:

SELECT MAX(B) as max FROM table

你可以这样做:

$stmt = $link->prepare("SELECT MAX($type) as max FROM table");

显然,如果 $type 来自用户,这很容易受到 SQL 注入(inject)攻击,但如果您从用户那里获取表名,那么您无论如何都做错了。

您的表格也可能像这样更有意义:

type | value
------------
A    | 0
B    | 50
C    | 0

然后你可以得到它:

SELECT MAX(value) FROM tableName WHERE type = :type

关于php - SQL 使用 PDO 获取单个标量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13425031/

相关文章:

php - Vagrant ,找不到 Apache 文件

php - 转移到同数据库的其他表mysql,有些字段是手动插入的,但直接删除源数据

sql - PostgreSQL 中一致的域/类型别名行为

mysql选择不同的字母,包括扩展的拉丁字符

PHP 可用性[]\用 mySQL 查询

php - 缓存来自 API 的数十亿响应的最快/最有效的方法是什么?

php - 有人可以清楚地解释为什么mysqli_prepare()/bind_param()比real_escape_string()更好吗?

php - 使用空参数运行 PHP 搜索脚本会返回整个 MySQL 表

php - MySQL轮怪异的bug

php - 二维数组不显示数据