PHP PDO Bit(1)返回错误的数据类型

时间:2012-03-12 10:35:05

标签: php mysql pdo sqldatatypes

当我使用PDO将此查询运行到mysql数据库时,它返回错误的数据类型。

<?php
$parameters = array(":1",92323);

$query = " SELECT s.Site_ID,s.Site_Url,s.Site_Name, s.Site_Approved, s.Site_Status, s.Thumbnailed ,st.Description AS Site_Status_Desc 
FROM Sites s
LEFT JOIN Sites_Status st ON st.Status_ID = s.Site_Status
WHERE s.Account_ID = :1";

try {

    $this->DBH = new PDO("mysql:host={$host};dbname={$db}", $user, $pass, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));

    $this->stmt = $this->DBH->prepare($query);


    if(count($parameters)>0) {

        foreach ($parameters as $key => $var) {

            switch ($var) {
                case is_int( $var ):
                    $this->stmt->bindValue($key,$var, PDO::PARAM_INT);
                    break;
                case is_bool( $var ):
                    $this->stmt->bindValue($key,$var, PDO::PARAM_BOOL);
                    break;
                case is_null( $var ):
                    $this->stmt->bindValue($key,$var, PDO::PARAM_NULL);
                    break;

                default:
                    $this->stmt->bindValue($key,$var, PDO::PARAM_STR);
                    break;
            }


        }

    }

    if($this->stmt->execute()) {

        // Set how many rows the query resulted in
        $this->num_rows = $this->stmt->rowCount();

        return $this->stmt->fetchObject();
    } else {
        return false;
    }

 } catch (PDOException $e) {
    $this->error_handler($e);
}

所有行都成为字符串作为数据类型,除了BIT字段,它变得不同......

public 'Site_Approved' => string '�' (length=1)

是否有动态方法使PDO返回正确的数据类型?

1 个答案:

答案 0 :(得分:10)

您正在使用Bit(1)字段来表示布尔值(TRUE / FALSE)。

数据库客户端将位字段(可以大于一位)映射到一个字符代表八位字节的字符串。

您可以通过ord()函数将您的Bit(1)字段用作PHP字符串,因为它将字符串视为单个Octet:

if (ord($Site_Approved)) {
     ...
}

您不能直接使用$Site_Approved,因为它是一个字符串,无论是否设置了第一位,它都会始终评估为TRUE

或者,您可以将SQL查询中的数据库值转换为可能正是您要查找的小数:

s.Site_Approved+0 AS Site_Approved

0到1范围内的十进制值与PHP的布尔值非常相似(它们只是不共享类型,其余部分相同)。