Sqlite中使用SQL与其他数据库的区别
发布时间:2020-12-12 19:55:57 所属栏目:百科 来源:网络整理
导读:Sqlite作为Android中的主流数据库而广为使用,但是他的sql语言与一般的大型数据库所使用的SQL语言还是有一些区别的,本文总结如下: 1、TOP 在SQL Server中,我们使用TOP来获取前N条数据: SELECT TOP 10 * FROM [index] ORDER BY indexid DESC; 但是在Sqlit
Sqlite作为Android中的主流数据库而广为使用,但是他的sql语言与一般的大型数据库所使用的SQL语言还是有一些区别的,本文总结如下: 1、TOP 在SQL Server中,我们使用TOP来获取前N条数据: SELECT TOP 10 * FROM [index] ORDER BY indexid DESC; 但是在Sqlite中,大家会发现这是不行的,我们需要这么写: SELECT * FROM [index] ORDER BY indexid DESC limit 0,10; 通过limit来实现TOP的功能。 2、COUNT(DISTINCT column) Sqlite无法执行以下语句: SELECT COUNT(DISTINCT watchid) FROM [watch_item] WHERE watch_item.watchid = 1; 其原因是SQLite的所有内置函数都不支持DISTINCT限定,所以如果要统计不重复的记录数的时候会出现一些麻烦。比较可行的做法是先建立一个不重复的记录表的视图,然后再对该视图进行计数。或者在插入数据的时候,就需要通过主键来判断。 3、Sqlite还无法使用外连 有解决的方法请指教。。。。 4、EXISTS语句 SQL Server中会这样写: IF NOT EXISTS (select * from aa where ids=5) BEGIN insert into aa(nickname) select 't' END Sqlite中会这样写: insert into aa(nickname) select 't' where not exists(select * from aa where ids=5) 如有新的东西,欢迎大家留言补充。 以上。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读