SQLite与SQL差异

SQLite官方网站: http://www.sqlite. org/ 时第一眼看到关于SQLite的特性。
  1. ACID事务
  2. 零配置 – 无需安装和管理配置
  3. 储存在单一磁盘文件中的一个完整的数据库
  4. 数据库文件可以在不同字节顺序的机器间自由的共享
  5. 支持数据库大小至2TB
  6. 足够小, 大致3万行C代码, 250K
  7. 比一些流行的数据库在大部分普通数据库操作要快
  8. 简单, 轻松的API
  9. 包含TCL绑定, 同时通过Wrapper支持其他语言的绑定
  10. 良好注释的源代码, 并且有着90%以上的测试覆盖率
  11. 独立: 没有额外依赖
  12. Source完全的Open, 你可以用于任何用途, 包括出售它
  13. 支持多种开发语言,C, PHP, Perl, Java, ASP .NET,Python
SQLite是遵守ACID的关联式数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。
    SQLite引擎不是独立进程,与常用数据库不同,它是连接到程序中成为它的一个主要部分。所以主要的通信协议是在编程语言内的直接API调用。这在消耗总量、延迟时间和整体简单性上有积极的作用。整个数据库(定义、表、索引和数据本身)都在宿主主机上存储在一个单一的文件中。它的简单的设计是通过在开始一个事务的时候锁定整个数据文件而完成的。

一、常见问题汇总
  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] FROMwatch_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];

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

    5 插入以及获得自增ID
    插入数据,对于标示种子的字段,SQLite必须指定为NULL,而获得新id,在sql server中是

SELECT @@IDENTITY [id]

sqlite中是

insert into t_1(id,name)values(NULL,'枯地');
select last_insert_rowid() newid;

  二、收集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不要丢弃,不然时间不准确。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值