OCaml - 带有ocaml-mysql

时间:2016-02-11 16:49:05

标签: mysql ocaml

我在使用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

1 个答案:

答案 0 :(得分:3)

Prepared.execute使用值而非任意表达式(函数调用)的数组。字符串值" CURRENT_TIMESTAMP"转换为时间戳,因为它无法识别为有效数字变为零。 正确传递NULL,它将根据CREATE TABLE默认初始化: P.execute_null insert [| None; Some "xxx.xxx.xxx.xxx"; Some text ; None |]