0

这个问题更多在这个帖子上。所以我想检索某一列中的数字。因此,假设表格如下所示:

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而不是数字。如何更改我的代码以获取号码?谢谢

4

1 回答 1

4
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");

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

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

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

然后你可以得到它:

SELECT MAX(value) FROM tableName WHERE type = :type
于 2012-11-16T22:05:34.650 回答