由于自己的孤陋寡闻, 也由于之前的项目中, 很少参与过数据库模块的开发, 以至于前几天才知道sqlite数据库也支持replace语句。 本文主要讲解在sqlite中replace语句的行为,也算是学习笔记。此外, replace语句和update语句有相似的地方, 但是也有很多不同之处。 本文还要对比一下sqlite中的 replace语句和update语句 。
在本例中使用如下数据库表:
(图 1)
该表的表名为student, 存储学生信息。 所有字段的数据类型都是TEXT 。 其中id和name作为复合主键。 email字段加上了唯一约束。建表语句如下:
1
2
3
4
5
6
7
8
9
10
|
CREATE
TABLE
IF
NOT
EXISTS student (
"id"
TEXT,
"name"
TEXT
NOT
NULL
,
"sex"
sql plain" style="border:0px!important; bottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.1em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
"email"
TEXT
UNIQUE
sql plain" style="border:0px!important; bottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.1em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
"fenshu"
CHECK
(fenshu > 0),
"tecid"
REFERENCES
teacher(id),
"class"
sql plain" style="border:0px!important; bottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.1em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
PRIMARY
KEY
(id,
name
)
)
|
replace语句的行为
1 replace语句会删除原有的一条记录, 并且插入一条新的记录来替换原记录。
为了验证这个结论, 下面打开sqlite命令行, 执行以下语句来替换id为2的记录。
(
'2'
sql plain" style="border:0px!important; bottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.1em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
'lisi'
'*F'
'123456@qq.com'
'80'
'1'
);
|
(图 2)
对比图1和图2 , 可以发现: 在图1中, id为2 的记录是表中的第一条记录, 当执行完上述的replace语句之后, id为2的记录位于整张表的最后。 这就说明, 这条replace语句删除了原有的id为2的记录, 有插入了一条新的id为2的记录。
2 一般用replace语句替换一条记录的所有列, 如果在replace语句中没有指定某列, 在replace之后这列的值被置空 。
下面我们还是以id为2 的记录做实验, 执行如下语句:
values
(
sql string" style="border:0px!important; bottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.1em!important; margin:0px!important; outline:0px!important; overflow:visible!important; padding:0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
该语句还是替换id为2, name为lisi的记录, 只是在指定列的时候, 没有指定class列。 在执行完成之后, 表中的数据如下:
|
"where"
: Syntax error
5 如果执行replace语句时, 不存在要替换的记录, 那么就会插入一条新的记录。
在student表中, 我们让id和name成为复合主键。 下面我们使用replace语句替换id为100, name为a 的记录。 从图3中可以看到, 表中存在name为a的记录, 但是这条记录的id为7, 而不是100 。也就是说 id为100, name为a 的记录不存在。
执行如下语句: