玉祥平台客服-15087858732

标题: 在 Oracle 数据库中保存空字符串 [打印本页]

作者: fteair    时间: 2020-6-23 14:18
标题: 在 Oracle 数据库中保存空字符串
向 Oracle 数据库表中,保存空字符串 '' ,结果成了 null.
由于数据库数值 null 的比较、判断,与空字符串 '' 存在差异。一不留神,代码中留下了 bug ,期望保存成空字符串 '' ,结果成了 null,SQL where 条件的结果,与预想的不同,导致结果数据也不同。
查网上资料,发现 Oracle 在空字符串 '' 的处理上,没有遵循 SQL 标准的做法。
实测 Oracle 11g 的 VARCHAR2 与 VARCHAR  两个字符串字段类型,都是保存后数据成了 null。
未测试 CHAR 类型,因为这个不符合我们的业务实际要求。
尝试翻阅各种网上文档(主要使用 bing 及 yahoo 搜索引擎,本来喜欢 google 搜索,可惜现在用不了;百度搜索的技术文章排序有问题,前几页的文章质量较低,没法用),也未找到合适的解决办法。
最后决定,在需要保存空字符串 '' 的地方,统一转换成保存字符串 '-' 。仅对于我们当前项目来说,是可以的。这也是无奈之举。
这篇资料里有说:There is no such thing as an empty string in Oracle
https://asktom.oracle.com/pls/asktom/f?p=100:11:0:::11_QUESTION_ID:5984520277372
不知道最新版的 Oracle ,是否提供了遵循 SQL 标准的字符串类型。


作者: caixuqad    时间: 2020-6-23 17:06

作者: 张兴康    时间: 2020-6-24 14:06

作者: fteair    时间: 2020-6-24 14:10
caixuqad 发表于 2017-8-23 17:06


作者: fteair    时间: 2020-6-24 14:11
张兴康 发表于 2017-8-24 14:06


作者: 张兴康    时间: 2020-6-25 14:27
fteair 发表于 2017-8-24 14:11


作者: fteair    时间: 2020-6-25 14:50
张兴康 发表于 2017-8-25 14:27


作者: caixuqad    时间: 2020-6-25 17:22

作者: caixuqad    时间: 2020-6-29 20:18

作者: fteair    时间: 2020-6-30 14:37
caixuqad 发表于 2017-8-30 17:17


作者: caixuqad    时间: 2020-6-30 17:17

作者: caixuqad    时间: 2020-6-30 17:46

作者: caixuqad    时间: 2020-7-1 14:56

作者: fteair    时间: 2020-7-1 15:09
caixuqad 发表于 2017-9-1 14:56


作者: caixuqad    时间: 2020-7-5 18:06

作者: fteair    时间: 2020-7-6 14:43
caixuqad 发表于 2017-9-5 18:06


作者: caixuqad    时间: 2020-7-6 17:53

作者: fteair    时间: 2020-7-7 15:23
caixuqad 发表于 2017-9-6 17:53


作者: caixuqad    时间: 2020-7-7 17:38





欢迎光临 玉祥平台客服-15087858732 (http://bbs.delit.cn/) Powered by Discuz! X3.2