从正常的思路来看,用户名肯定是作为字符串记录的,怎么可能作为代码出现被当作空指针。另数据库无法识别更让我难以理解。
可是最近看到了好几条类似的新闻,这是炒作还是什么?
本人对数据库只有基本的一些了解,对此很是好奇,希望有人解答一下。谢过。
1
zhfy1991 2016-04-01 10:37:52 +08:00 via Android
有时候会用 str==null||str.equals("null")来做空判断,中枪。
|
2
DarryO OP @zhfy1991 那请问,为什么需要 str.equals("null") 这个判断是为了干什么呢? null 会有为什么会变成 "null" ?
|
3
lhbc 2016-04-01 11:03:31 +08:00
代码写得不严谨,当然会出错
|
4
zhfy1991 2016-04-01 13:20:11 +08:00 via Android
@DarryO 我这种就是代码不严谨的情况了,一种可能的情况是比如某字段是空,然后修改对象的时候查出来直接放在表单上,表单上就显示了"null",然后保存的时候就把字符串"null"存进去了, 下一次再查询这个字段就是字符串"null"了。
尤其是如果编辑功能和查询功能不是同一个人写的,更容易出现这种情况。 |
5
dong3580 2016-04-01 13:22:34 +08:00
增删改查请用参数化查询,这是"null",不是 null
|
6
BOYPT 2016-04-01 13:35:32 +08:00
最常见就是收工拼装 SQL 语句啊,字符串拼进去当然也是字符串。有多难理解?
|
7
lyragosa 2016-04-01 13:36:32 +08:00
改名为 Undefined Empty Null 效果更佳
|