When I run this query with PDO in mysql db, it returns the wrong data types.
<?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()) {
All strings become strings as data types, except for the BIT field, it becomes something else ...
public 'Site_Approved' => string ' ' (length=1)
Is there a dynamic way to get PDOs to return the correct data types?
Gomer source share