我在使用ocaml-mysql(最新版本)库执行以下MySQL语句时遇到问题:
let dump_to_db text =
let insert = P.create db (s "INSERT INTO Temperature VALUES (?,?,?,?)") in
ignore (P.execute insert [| "NULL"; "xxx.xxx.xxx.xxx"; text ; "CURRENT_TIMESTAMP" |])
我的问题是时间戳字段设置不正确。显然,无论我写入最后一个字段(可能是“CURRENT_TIMESTAMP”还是“NULL”),我都无法得到正确的结果。
发生的是查询被执行,我在表中看到的是一个空填充的Timestamp字段(即使我不知道它是如何可能的,因为它被定义为NOT NULL列)。
我的表结构如下:
CREATE TABLE `Temperature` (
`ID` bigint(20) NOT NULL AUTO_INCREMENT,
`IP` varchar(100) DEFAULT NULL,
`Value` varchar(100) DEFAULT NULL,
`Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1
答案 0 :(得分:3)
Prepared.execute
使用值而非任意表达式(函数调用)的数组。字符串值" CURRENT_TIMESTAMP"转换为时间戳,因为它无法识别为有效数字变为零。
正确传递NULL
,它将根据CREATE TABLE
默认初始化:
P.execute_null insert [| None; Some "xxx.xxx.xxx.xxx"; Some text ; None |]