gpt4 book ai didi

MySQL 5.7 日期字段问题

转载 作者:行者123 更新时间:2023-11-29 02:47:45 24 4
gpt4 key购买 nike

我最近安装了 MySQL 5.7。日期列发生了一些奇怪的事情。

如果我在 WHERE 部分使用该字段执行 SELECT 查询,我有一个结果集,但是当我使用相同的 WHERE 条件更新一行时,我得到一个无效的日期格式 错误信息。

这是SELECT语句:

SELECT *
FROM
FDpoCargTran
WHERE FDpoCargTran.Banco = '001'
AND (FDpoCargTran.Conciliacion = '' OR FDpoCargTran.Conciliacion IS NULL)
AND FDpoCargTran.Fecha = '2016-09-27'

这句话返回2行resultset,没问题。

现在,这是更新语句:

UPDATE
FDpoCargTran
SET
Edo = 'C'
WHERE FDpoCargTran.Banco = '001'
AND (FDpoCargTran.Conciliacion = '' OR FDpoCargTran.Conciliacion IS NULL)
AND FDpoCargTran.Fecha = '2016-09-27'
AND Deposito = 1041

我收到此错误消息:

Data truncation: Incorrect date value: '' for column 'Conciliacion'

Conciliacion 列定义为:

`Conciliacion` date DEFAULT NULL, 

如果我删除 Conciliacion = '' 条件,一切正常。

为什么空字符串对于 UPDATE 语句中而不是 SELECT 中的列求值无效?

拜托,一个想法!!!

最佳答案

Basically, for date datatype, you cannot store something like White Spaces or ' ' strings. You need to make the column to accept NULL values and insert an actual NULL into it. This is not a problem in MySQL 5.7, its how date is set in databases.

Update 是一个 DML 语句,当你真的想往表中写入一些东西,或者检查一个条件时,MySQL 无法理解日期列类型的 ' ' 是什么。

因此,您不能设置 ' ',而可以设置 NULL。这就是 MySQL 检查条件并进行适当更改的方式!!

我建议,将其更改为 NULL。

  1. 将日期时间列更改为 varchar。
  2. 导入任何表/数据库。
  3. 更新 FDpoCargTran set Conciliacion=NULL where Conciliacion='';
  4. 将列改回日期时间。

关于MySQL 5.7 日期字段问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39737396/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com