update语句

SQLite这种微型数据库用到的语句非常少,所以可能我们不会经常的用到。但要想真正的玩转sqlite这种微型数据库,掌握这些语句的用法是非常重要的。

SQLite数据库不支持update...from语句,但可以用两种不同的方法来替代它。

本文我们就来介绍一下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语句的知识就介绍到这里,希望能给大家带来帮助吧。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值