码迷,mamicode.com
首页 > 数据库 > 详细

sqlite查询问题,由字母大小写敏感引起

时间:2018-08-13 14:06:16      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:user   就是   分享   技术   ase   服务   数据库   table   png   

目前做的项目之前是用mysql,这是个错误的选择,因为本身并不是服务器-客户端模式的项目,而是一个CS架构项目,mysql这种需要较繁复配置的数据库并不合适。需要的应该是sqlite这类,内嵌的数据库。

所以最近统一做数据库替换工作,将之前mysql数据库操作的所有接口统一改成sqlite数据库操作的接口。

按道理讲sql语句都是一样的,只要改下调用的数据库C++接口就可以了。

然后就出现一个问题,一个表的查询一直是错的。

经过调试和实验发现,查询语句中用户ID都是大写字母,实际数据库中含有小写字母。

技术分享图片

查询为空因为这串user_id  ‘F56DC7AD-2AAB-499C-A1A5-0EFC154E15E2‘ 都是大写字母。

实际上:

技术分享图片

user_id为:F56DC7AD-2AAB-499c-A1A5-0EFC154E15E2,含有小写字母

 

为什么之前在mysql中没有这样的问题呢?

因为在mysql中查询对字母大小写不敏感:

技术分享图片

可以看出,即使f这个字母大小写不一致,还是成功查到了

 

最后我解决这个问题方法就是,让原本大小写敏感的sqlite变成大小写不敏感,这样就与之前的mysql保持一致。

建表时:

 CREATE TABLE if not exists user_cert (user_id char(128) NOT NULL  COLLATE NOCASE,cert_id char(128) NOT NULL,id integer  primary key autoincrement);

特表规定 COLLATE NOCASE就可以了。

sqlite查询问题,由字母大小写敏感引起

标签:user   就是   分享   技术   ase   服务   数据库   table   png   

原文地址:https://www.cnblogs.com/rixiang/p/9467329.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!