[英]PHP prepared statement -> only returns first letter from a column in database
我有这个代码
$sql = "SELECT name FROM data WHERE id=? LIMIT 0,1";
//prepares statement
$stmt = self::getConnection()->prepare($sql);
$stmt->bind_param("i", $id);
$ids = array(1,2,3);
foreach ($ids as $key => $id) {
$stmt->execute();
$stmt->bind_result($name);
$stmt->fetch();
$stmt->store_result();
var_dump($name);
}
我的数据库表看起来像这样
id | name
1 | First Name
2 | Second Name
3 | Third Name
现在输出如下:
string(10) "First Name"
string(1) "S"
string(1) "T"
第一个名字是正确的。 但是它只输出以下行的第一个字母。 我不知道为什么。 我尝试了另一个整数类型的列。 那很有效。 只是这个字符串类型的列没有。
我还试图改变$ids-Array
,如下所示: $ids = array(2,3,1)
。 然后输出
string(11) "Second Name"
string(1) "T"
string(1) "F"
我不知道该怎么做。 有谁看到我的错误?
编辑:
PHP 5.5和Mysql 5.5.31以及var_dump:
编辑2:
-- phpMyAdmin SQL Dump
-- version 4.0.5
-- http://www.phpmyadmin.net
--
-- Host: rdbms
-- Erstellungszeit: 07. Jun 2014 um 19:21
-- Server Version: 5.5.31-log
-- PHP-Version: 5.3.27
SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
--
-- Datenbank: `DB1673555`
--
-- --------------------------------------------------------
CREATE TABLE IF NOT EXISTS `data` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` tinytext NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=4 ;
INSERT INTO `data` (`id`, `name`) VALUES
(1, 'First Name'),
(2, 'Second Name'),
(3, 'Third Name');
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
我刚看到转储说我使用的是PHP 5.3。 但是在strato的网站上他们说5.5
这是我发现的。 我认为它的原因是tinytext
。 因为当我使用您的数据库转储然后在我的本地PC上重现错误。 但是一旦我将列类型更改为varchar 255
那么代码工作正常。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.