首页 > 数据库技术 > 详细

面试3 - 数据库

时间:2014-11-09 23:28:20      阅读:253      评论:0      收藏:0      [点我收藏+]

mysql如何实现插入时如果不存在则插入如果存在则更新的操作?

在Oracle中有merge into来实现记录已存在就更新的操作,mysql没有merge into语法,但是有replace into的写法,同样实现记录已存在就更新的操作。 SQL Server中的实现方法是:

if not exists (select 1 from t where id = 1)

insert into t(id, update_time) values(1, getdate())

else

update t set update_time = getdate() where id = 1

MySQL replace into 有三种形式:

1. replace into tbl_name(col_name, …) values(…)

2. replace into tbl_name(col_name, …) select …

3. replace into tbl_name set col_name=value, …

其中 “into” 关键字可以省略,不过最好加上 “into”,这样意思更加直观。另外,对于那些没有给予值的列,MySQL 将自动为这些列赋上默认值。

 

面试3 - 数据库

原文:http://www.cnblogs.com/xiaowei-blog/p/4086069.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!