千家信息网

SQLite与SQL差异的常见问题有哪些

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章主要介绍了SQLite与SQL差异的常见问题有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、常见问题汇总1 TOP这是
千家信息网最后更新 2025年01月20日SQLite与SQL差异的常见问题有哪些

这篇文章主要介绍了SQLite与SQL差异的常见问题有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一、常见问题汇总

1 TOP

这是一个大家经常问到的问题,例如在SQLSERVER中可以使用如下语句来取得记录集中的前十条记录:

SELECT TOP 10 * FROM [index] ORDER BY indexid DESC;

但是这条SQL语句在SQLite中是无法执行的,应该改为:

SELECT * FROM [index] ORDER BY indexid DESC limit 0,10;

其中limit 0,10表示从第0条记录开始,往后一共读取10条

2 创建视图(Create View)

SQLite在创建多表视图的时候有一个BUG,问题如下:

CREATE VIEW watch_single AS SELECT DISTINCTwatch_item.[watchid],watch_item.[itemid] FROM watch_item;

上面这条SQL语句执行后会显示成功,但是实际上除了

SELECT COUNT(*) FROM [watch_single ] WHERE watch_ single.watchid = 1;

能执行之外是无法执行其他任何语句的。其原因在于建立视图的时候指定了字段所在的表名,而SQLite并不能正确地识别它。所以上面的创建语句要改为:

CREATE VIEW watch_single AS SELECT DISTINCT [watchid],[itemid] FROM watch_item;

但是随之而来的问题是如果是多表的视图,且表间有重名字段的时候该怎么办?

3 COUNT(DISTINCT column)

SQLite在执行如下语句的时候会报错:

SELECT COUNT(DISTINCT watchid) FROM [watch_item] WHERE watch_item.watchid = 1;

其原因是SQLite的所有内置函数都不支持DISTINCT限定,所以如果要统计不重复的记录数的时候会出现一些麻烦。比较可行的做法是先建立一个不重复的记录表的视图,然后再对该视图进行计数。

4 外连接

虽然SQLite官方已经声称LEFT OUTER JOIN 已经实现,但还没有 RIGHT OUTER JOIN 和 FULL OUTER JOIN。但是实际测试表明似乎并不能够正常的工作。以下三条语句在执行的时候均会报错:

SELECT tags.[tagid] FROM [tags],[tag_rss] WHERE tags.[tagid] = tag_rss.[tagid](*);  SELECT tags.[tagid] FROM [tags],[tag_rss] WHERE LEFT OUTER JOIN tag_rss.[tagid] = tags.[tagid];  SELECT tags.[tagid] FROM [tags],[tag_rss] WHERE LEFT JOIN tag_rss.[tagid] = tags.[tagid];

此外经过测试用+号代替*号也是不可行的。

二、收集SQLite与Sql Server的语法差异

1.返回最后插入的标识值

返回最后插入的标识值sql server用@@IDENTITY

sqlite用标量函数LAST_INSERT_ROWID()

返回通过当前的 SQLConnection 插入到数据库的最后一行的行标识符(生成的主键)。此值与 SQLConnection.lastInsertRowID 属性返回的值相同。

2.top n

在sql server中返回前2行可以这样:

select top 2 * from aa   order by ids desc

sqlite中用LIMIT,语句如下:

select * from aa   order by ids desc   LIMIT 2

3.GETDATE ( )

在sql server中GETDATE ( )返回当前系统日期和时间

sqlite中没有

4.EXISTS语句

sql server中判断插入(不存在ids=5的就插入)

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)

5.嵌套事务

sqlite仅允许单个活动的事务

6.RIGHT 和 FULL OUTER JOIN

sqlite不支持 RIGHT OUTER JOIN 或 FULL OUTER JOIN

7.可更新的视图

sqlite视图是只读的。不能对视图执行 DELETE、INSERT 或 UPDATE 语句,sql server是可以对视图 DELETE、INSERT 或 UPDATE

三、新增内容

1.关于日期时间类型列的默认设置:

对"列"的设置包括三个字段:Name、Type、Default

Name:logTime(随意命名);

Type:

Date类型,得到的值形如"2011-04-23",

DATETIME类型,得到的值形如"2011-04-23 11:49:04.000";

Default:datetime('now','localtime') 我采用的是两个参数,后面的localtime不要丢弃,不然时间不准确。

感谢你能够认真阅读完这篇文章,希望小编分享的"SQLite与SQL差异的常见问题有哪些"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

语句 视图 问题 时候 篇文章 差异 常见 常见问题 字段 时间 标识 类型 支持 事务 函数 原因 实际 日期 会报 测试 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 宝塔的数据库如何打开 内存数据库的应用场景 奥迪斯服务器扶梯查看故障方法 网络安全等级保护小知识 网络安全班会课总结 h2 数据库 远程连接 濮阳网络技术联系方式 网络技术专业用什么电脑好 三门峡春暖花开网络技术有限公司 长沙图书馆数据库 市医院网络安全 新技术的网络安全测试 dw数据可视化代码连接数据库 网络安全登记保护 三级 浙江系统软件开发机构 网络安全马克笔画的图片 深圳软件开发公司费用标准 三星贴片机元件数据库对照表 架构图软件开发背景 力控科技互联网怎么解决 开展网络安全教育简讯 广安经开区网络安全宣传周活动 实名制号码验证服务器失败 小程序云服务器怎么配置 网络技术方面的公众号 服务器关闭安全配置 西电成都网络安全研究院地址 网络安全宣传周上海交大 数据库和vc怎么安装软件 2020网络安全周专题
0