关于Sqlite数据库Update语句的一点介绍

数据库 其他数据库
sqlite数据库不支持update……from语句,但可以用两种不同的方法来替代它,本文主要介绍了这一过程,接下来就让我们一起学习吧。

Sqlite数据库中的Update语句,你能了解多少呢?因为这种微型数据库用到的语句非常少,所以可能我们不会经常的用到。但要想真正的玩转sqlite这种微型数据库,掌握这些语句的用法是非常重要的。本文我们就来介绍一下update语句的使用。

1.典型的Update(支持)

 

  1. Update  
  2.  
  3. T1  
  4.  
  5. Set  
  6.  
  7. Column1=v1,  
  8.  
  9. Column2=V2 
  10.  
  11. Where  
  12.  
  13. key=V3

 

2.Update…From(很不幸,Sqlite是不支持的)

  1. UPDATE  
  2.  
  3. t1  
  4.  
  5. SET  
  6.  
  7. Column1=t2.Column1  
  8.  
  9. FROM  
  10.  
  11. t2,t1  
  12.  
  13. WHERE  
  14.  
  15. t2.key=t1.key; 

 

要进行表间更新Update…From是必须的,居然Sqlite不支持,有什么别的办法吗?还确实有,替代方法有两种:

首先,Sqlite里面有一个新鲜玩意“INSERTORREPLACE”,跟Mysql类似,这个结构能够保证在存在的情况下替换,不存在的情况下更新,用这个机制就可以轻松实现Update…From了。

 

  1. INSERTORREPLACEINTO  
  2.  
  3. t1(key,Column1,Column2)  
  4.  
  5. SELECT  
  6.  
  7. t2.key,t2.Column1,t2.Column2  
  8.  
  9. FROM  
  10.  
  11. t2,t1  
  12.  
  13. WHERE  
  14.  
  15. t2.key=t1.key; 

 

备注:这种方法要避免插入操作,首先要确保是依照主键执行的更新,如果where条件不是主键可能就有点麻烦了。

要是不是主键的更新怎么办能?另外还有其他的办法吗?我们在这中情况下只能向典型的Update…where寻求帮助了,下面是一个例子:

 

  1. UPDATE  
  2.  
  3. t1  
  4.  
  5. SET  
  6.  
  7. Column1=(SELECTColumnxFROMt2WHEREt2.key=t1.key),  
  8.  
  9. Column2=(SELECTColumnyFROMt2WHEREt2.key=t1.key),  
  10.  
  11. WHEREt1.key=(SELECTkeyFROMt2WHEREt2.key=t1.key); 

 

下面举一个主从表的例子,一个部门表,一个成员表,成员表中的部门名称和代码是冗余的信息,以部门表中的部门名称和代码更新成员表中的冗余信息:

 

  1. update  
  2.  
  3. userlogins  
  4.  
  5. set  
  6.  
  7. deptname=(selectdeptnamefromDepartMentswhereDepartMents.[DeptID]=userlogins.[DeptID]),  
  8.  
  9. deptcode=(selectdeptcodefromDepartMentswhereDepartMents.[DeptID]=userlogins.[DeptID])  
  10.  
  11. where  
  12.  
  13. userlogins.[DeptID]=(SELECT[DeptID]FROM DepartMentswhereDepartMents.[DeptID]=userlogins.[DeptID]); 

 

关于sqlite数据库的update语句的知识就介绍到这里,希望能给大家带来帮助吧。

【编辑推荐】

  1. 简述修复Domino数据库视图索引的两种方法
  2. MSSQL数据库跨表和跨数据库查询方法简介
  3. Oracle跟踪文件分析工具TKPROF使用简介
  4. 在SQL SERVER 2005执行存储过程的权限分配问题
  5. SQL Server 2005数据库分区数据的移入和移出操作
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-07-12 17:55:28

尾日志备份

2011-04-07 10:13:48

数据库开发

2011-07-18 16:33:20

sqlite

2009-12-28 09:51:17

Fedora GNOM

2011-08-30 14:15:34

QTSQLite数据库

2011-06-30 15:26:28

Update数据库

2012-03-27 08:49:19

Json

2009-12-14 17:28:18

Visual Stud

2009-11-23 16:26:37

Visual stud

2011-05-24 11:09:30

Access数据库

2012-07-12 10:49:53

项目管理

2014-06-04 10:48:38

Swift苹果iOS

2013-12-30 09:31:34

Node.js技术

2020-12-10 06:23:19

数据库阿里云RDS

2013-06-24 10:31:38

2010-04-02 12:23:30

Oracle数据库

2020-12-08 09:52:22

数据库工具技术

2009-03-11 10:42:52

更新查询MySQL

2009-08-03 09:17:30

ASP.NET Ses

2011-07-14 16:17:47

AmoebaMySQL
点赞
收藏

51CTO技术栈公众号