我有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
答案 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'";