十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
原由:在使用SpringDataJPA语句进行对数据库表的某个字段的空值查询时,如:
findByIdAndNameIsNull
findByIdAndNameIsNotNull
当name这个字段值为''空串时,查询出来的结果差异很大
创新互联是一家专注网站建设、网络营销策划、成都微信小程序、电子商务建设、网络推广、移动互联开发、研究、服务为一体的技术型公司。公司成立10年以来,已经为千余家成都高空作业车租赁各业的企业公司提供互联网服务。现在,服务的千余家客户与我们一路同行,见证我们的成长;未来,我们一起分享成功的喜悦。
CREATE TABLE `user` (
`id` bigint(11) NOT NULL AUTO_INCREMENT,
`name` varchar(45) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
`age` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
)
Mysql8.0.13:
UPDATE `user` u SET u.`name` = '' WHERE u.id = 4
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NOT NULL--有值
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NULL--无值
UPDATE `user` u SET u.`name` = NULL WHERE u.id = 4
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NOT NULL--无值
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NULL--有值
Oracle11g:
UPDATE `user` u SET u.`name` = '' WHERE u.id = 4
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NOT NULL--无值
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NULL--有值
UPDATE `user` u SET u.`name` = NULL WHERE u.id = 4
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NOT NULL--无值
SELECT * FROM `user` u WHERE u.id = 4 AND u.`name` IS NULL--有值
综上:可以看到Oracle数据库认为无论''空串还是null均为空,而Mysql则严格意义null才是空
JPA查询
List findByIdAndNameIsNull;
List findByIdAndNameIsNotNull;
插入测试数据
INSERT INTO `user`(`id`, `name`, `age`) VALUES (4, NULL, 22);
INSERT INTO `user`(`id`, `name`, `age`) VALUES (5, '', 22);
INSERT INTO `user`(`id`, `name`, `age`) VALUES (6, '', 22);
运行并查看结果:
List
id=4
List
id=5和id=6
总结:JPA查询认为null才是严格意义上的空!
在实际生产中我们泛意义的认为''和null都为空,这样在使用JPA进行查询时,要避免使用含Null的查询,可以使用HQL进行查询细化
// 查询空字段
SELECT u FROM UserDo u WHERE u.id = 4 AND (u.name is null or u.name ='')
// 查询非空字段
SELECT u FROM UserDo u WHERE u.id = 4 AND (u.name is not null and u.name <>'')