SQLite数据库创建临时表、增加列的方法

前端之家收集整理的这篇文章主要介绍了SQLite数据库创建临时表、增加列的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

这两天帮朋友做一个关于地热数据处理的小软件再次用到了sqlite数据库,不过这次不是使用其缓存/内存数据库功能,而是纯粹将其作为一个嵌入式文件数据库来使用的,其实对于数据量级相对比较小的系统而言,嵌入式数据库sqlite绝对是一个非常理想的选择。但是,话又说回来,毕竟是一个没有DBA的数据库系统,因此所能实现的功能相对就比较简单,这不,遇到了想在一张表中增加一列的功能时着实让我头疼了一个下午的时光。

我们都知道,数据库表中增加/删除一列用sql语句实现很简单:

alter table 表名称 add 列名称 数据类型; // 数据库表中增加一列

alter table 表名称 drop column 列名称 数据类型; // 数据库删除一列

但是,对于sqlite数据库而言有两个问题:

(1) 可以增加一列,但是该列只能是表的最后一列。

(2)不能删除一列。

对于第一个问题,如果你不觉得不爽的话,也没什么关系,并不影响使用,但是对于第二条而言问题就很大了,不支持删除一列还是很麻烦的事情。还要,条条大路通帝都。通过创建临时表的方法,可以很好的解决这个问题。

其实,说简单点儿,如果想删除表A中的一列或者一行,我们首先通过sql创建一个临时表,然后把表A中期望保留的数据存储到临时表中,然后把表A删除,再通过sql的create语句创建表A,最后将临时表中的数据再复制回来,算是一种曲线解决问题的方法吧。^_^

还是举两个例子说明最简单明了。

例1:在表coordinate中增加一列自动增长的id列。

  1. BEGIN@H_301_27@@H_301_27@TRANSACTION@H_301_27@;@H_301_27@@H_301_27@
  2. CREATE@H_301_27@@H_301_27@TEMPORARY@H_301_27@@H_301_27@TABLE@H_301_27@ptemp(provinceID@H_301_27@int@H_301_27@,longitude@H_301_27@double@H_301_27@,latitude@H_301_27@double@H_301_27@);@H_301_27@@H_301_27@
  3. INSERT@H_301_27@@H_301_27@INTO@H_301_27@ptemp@H_301_27@SELECT@H_301_27@provinceID,longitude,153); background-color:inherit; font-weight:bold">FROM@H_301_27@coordinate;@H_301_27@@H_301_27@
  4. DROP@H_301_27@@H_301_27@TABLE@H_301_27@coordinate;@H_301_27@@H_301_27@
  5. TABLE@H_301_27@provincecoordinate(id@H_301_27@INTEGER@H_301_27@@H_301_27@PRIMARY@H_301_27@@H_301_27@KEY@H_301_27@AUTOINCREMENT,provinceID@H_301_27@double@H_301_27@);@H_301_27@@H_301_27@
  6. INTO@H_301_27@provincecoordinate(provinceID,latitude)@H_301_27@FROM@H_301_27@ptemp;@H_301_27@@H_301_27@
  7. TABLE@H_301_27@ptemp;@H_301_27@@H_301_27@
  8. COMMIT@H_301_27@;@H_301_27@@H_301_27@

例2:在表china中增加一列自动增长的id列。@H_301_27@

?
    TABLE@H_301_27@ptemp(longitude@H_301_27@SELECT@H_301_27@longitude,153); background-color:inherit; font-weight:bold">FROM@H_301_27@china;@H_301_27@@H_301_27@
  1. TABLE@H_301_27@china;@H_301_27@@H_301_27@
  2. TABLE@H_301_27@china(id@H_301_27@INTO@H_301_27@china(longitude,153); background-color:inherit; font-weight:bold">COMMIT@H_301_27@;@H_301_27@@H_301_27@

猜你在找的Sqlite相关文章