MYSQL选择时间戳数据无法检索的位置

时间:2014-03-11 09:52:45

标签: php mysql

我有mysql表如下;

CREATE TABLE IF NOT EXISTS `cheque_data` (
`auto_no` int(11) NOT NULL AUTO_INCREMENT,
`job_no` int(11) NOT NULL,
`client_id` text NOT NULL,
`ch_no` text NOT NULL,
`ch_date` date NOT NULL,
`ch_bank` text NOT NULL,
`ch_amount` decimal(10,2) NOT NULL,
`sync` int(1) NOT NULL DEFAULT '0',
`timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
 PRIMARY KEY (`auto_no`)
 )

当我在PHPMYADMIN中运行SQL命令时,它将检索行;

SELECT * FROM `cheque_data` WHERE timestamp='2014-03-10 19:37:31'.

但在PHP中,

$sql = "select * from `cheque_data` where timestamp = '2014-03-10 19:37:31'";
$result_remote = mysqli_query($con,$sql) or die(mysqli_error($con));
$row_count = mysqli_num_rows($result_remote);
echo $row_count; //no data

它不提供任何数据。但是,当我将时间戳更改为其他列时,它可以正常工作。

$sql = "select * from `cheque_data` where auto_no = '1'";
$result_remote = mysqli_query($con,$sql) or die(mysqli_error($con));
$row_count = mysqli_num_rows($result_remote);
echo $row_count; //data found

我想知道,这个问题的原因是什么? 它只适用于时间戳

的位置

谢谢你, Sameera

2 个答案:

答案 0 :(得分:0)

问题可能是PHP脚本中的问题,而不是MySQL。 附:请记住,最好在`中包装列名不要混淆MySQL。在你的陈述中它是可以的,但是fyi有一个名为TIMESTAMP()的函数,在某些情况下,MySQL可能会想到column name的非function name

答案 1 :(得分:0)

在timestamp字段周围添加反引号(`),因为它是保留字或使用此查询

$sql = "select * from `cheque_data` where `timestamp` = '2014-03-10 19:37:31'";