向 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 标准的字符串类型。
|