标题:请教字符转日期
只看楼主
fanjinyu9108
Rank: 2
等 级:论坛游民
帖 子:644
专家分:20
注 册:2014-1-16
结帖率:88.5%
已结贴  问题点数:20 回复次数:8 
请教字符转日期
电子表的单元格是日期型的,比如“2023年1月8日”,导入数据库,用CTOD()函数出来的却是空值,比如 CTOD('2023年1月8日'),请问怎么办?
搜索更多相关主题的帖子: 数据库 空值 函数 字符 日期 
2023-02-08 16:48
laowan001
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:54
帖 子:802
专家分:1914
注 册:2015-12-30
得分:5 
MESSAGEBOX(CTOD(CHRTRANC('2023年1月8日','年月日','..')))
2023-02-08 17:09
fanjinyu9108
Rank: 2
等 级:论坛游民
帖 子:644
专家分:20
注 册:2014-1-16
得分:0 
谢谢laowan001师傅的解答,这个问题解决了,但是在存盘到SQL数据库的时候,还是遇到麻烦,在SQL端,我设置字段的类型是DATE,使用函数dtoc(CTOD(CHRTRANC(xx1,'年月日','..')))存盘到SQL数据库,当电子表格的单元格有日期时
就能正常存盘,但是当电子表格的单元格是空值时,就不能存盘,也就说SQL的DATE时不允许有空白值的(不是NULL),是这样的吗?但是我的表日期有时必须是空值,遇到这样的问题怎么解决呢?是不是还是要把字段设置成字符型的。
2023-02-08 18:39
csyx
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:29
帖 子:484
专家分:1827
注 册:2018-3-13
得分:5 
把后端数据库该字段改成允许 Null 带来的前端代码修改,其工作量总比改成字符型的小吧?
2023-02-08 18:53
fanjinyu9108
Rank: 2
等 级:论坛游民
帖 子:644
专家分:20
注 册:2014-1-16
得分:0 
我说的空白不是null,就是屏幕显示空白,NULL值屏幕显示也是NULL

[此贴子已经被作者于2023-2-8 19:34编辑过]

2023-02-08 19:29
laowan001
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:54
帖 子:802
专家分:1914
注 册:2015-12-30
得分:0 
日期格式没有空白,需要的话可以在前台把日期转换为字符型,当NULL值时赋值空白
2023-02-09 10:43
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:5 
以下是引用fanjinyu9108在2023-2-8 19:29:12的发言:

我说的空白不是null,就是屏幕显示空白,NULL值屏幕显示也是NULL

有个 SET 命令可以设置 NULL 显示为空
2023-02-09 14:44
fanjinyu9108
Rank: 2
等 级:论坛游民
帖 子:644
专家分:20
注 册:2014-1-16
得分:0 
请教这是什么命令?
2023-02-09 16:31
igaoyuan
Rank: 2
等 级:论坛游民
帖 子:84
专家分:49
注 册:2022-12-19
得分:5 
回复 楼主 fanjinyu9108
试试先把excel表格的日期格式变更为ansi格式,然后再导入
2023-02-09 20:57



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-511235-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.053222 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved