使用PDO和MySQL从表中的列检索值

时间:2013-08-19 11:01:18

标签: php mysql pdo

我使用以下内容记录我的用户,

/*** select the users name from the database ***/
    $dbh = new PDO("mysql:host=$mysql_hostname;dbname=$mysql_dbname", $mysql_username, $mysql_password);

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

    $stmt = $dbh->prepare("SELECT * FROM access_users 
    WHERE id = :phpro_user_id");

    $stmt->bindParam(':phpro_user_id', $_SESSION['user_id'], PDO::PARAM_INT);

    $stmt->execute();

    $username = $stmt->fetchColumn();

    if($username == false)
    {
    $message = 'Access Error';
    }
    else
    {
        // done
    }

我想检索用户level值,这是我表格中的一列,我不确定如何使用PDO执行此操作?

我试过......

print $result->level;

2 个答案:

答案 0 :(得分:2)

由于无法从您的问题中获取,您要检索哪一列,假设它被称为“用户名”:

$stmt = $dbh->prepare("SELECT username FROM access_users WHERE id = ?");
$stmt->execute(array($_SESSION['user_id']));
$username = $stmt->fetchColumn();

这就是fetchColumn()的工作方式。

但是如果你想获得所有用户信息,,其中包含级别和用户名,你必须检索通常的方式,整行。

$stmt = $dbh->prepare("SELECT * FROM access_users WHERE id = ?");
$stmt->execute(array($_SESSION['user_id']));
$row = $stmt->fetch();
if(!$row['level'])
{
    $message = 'Access Error';
}
echo "Hello ".$row['username'];

答案 1 :(得分:0)

尝试以下方法:

$stmt = $dbh->prepare("SELECT user_id,level FROM access_users 
    WHERE id = :phpro_user_id");

//rest of the code up until here

$result = $stmt->fetchColumn(1);

print("level= $result\n");