SQLite中的自增关键字:AUTO_INCREMENT、INTEGER PRIMARY KEY与AUTOINCREMENT
1、SQLite不支持关键字AUTO_INCREMENT
1)AUTO_INCREMENT不生效的问题
SQL语句:
CREATE TABLE todo
(
id INTEGER AUTO_INCREMENT,
title TEXT,
PRIMARY KEY (id)
);
问题描述:按照上述SQL语句创建表todo,用INSERT INTO todo (title) VALUES ('xxx')插入记录,但查询该记录后得到的id为NULL(即Python中的None)
实验脚本:
#!/usr/bin/python
# -*- encoding: utf-8 -*- import sqlite3
con = sqlite3.connect(":memory:") # 创建表
con.execute("""
CREATE TABLE todo
(
id INTEGER AUTO_INCREMENT,
title TEXT,
PRIMARY KEY (id)
);""") # 插入记录
con.execute("INSERT INTO todo (title) VALUES ('shopping');") # 查询记录
for row in con.execute("SELECT * FROM todo"):
print row
运行结果:
$ python auto_increment_null.py
(None, u'shopping')
2)AUTO_INCREMENT导致语法错误的问题
SQL语句:
CREATE TABLE todo
(
id INTEGER PRIMARY KEY AUTO_INCREMENT,
title TEXT
);
问题描述:根据SQL的语法,按理说上述SQL语句应该与1)中的SQL语句等效,但运行结果却是语法错误
实验脚本:
#!/usr/bin/python
# -*- encoding: utf-8 -*- import sqlite3
con = sqlite3.connect(":memory:") # 创建表
con.execute("""
CREATE TABLE todo
(
id INTEGER PRIMARY KEY AUTO_INCREMENT,
title TEXT
);""") # 插入记录
con.execute("INSERT INTO todo (title) VALUES ('shopping');") # 查询记录
for row in con.execute("SELECT * FROM todo"):
print row
运行结果:
$ python auto_increment_error.py
Traceback (most recent call last):
File "auto_increment_error.py", line , in <module>
);""")
sqlite3.OperationalError: near "AUTO_INCREMENT": syntax error
上述两个问题在《AUTO_INCREMENT in sqlite problem with python》中得到了解释和解答:在SQLite中,自增字段需要使用关键字INTEGER PRIMARY KEY。
2、自增关键字INTEGER PRIMARY KEY
SQL语句:
CREATE TABLE todo
(
id INTEGER PRIMARY KEY,
title TEXT
);
或者
CREATE TABLE todo
(
id INTEGER PRIMARY KEY NOT NULL,
title TEXT
);
按照上述SQL语句创建表todo,用INSERT INTO todo (title) VALUES ('xxx')或者INSERT INTO todo (id, title) VALUES (NULL, 'xxx')插入记录,查询记录后得到的id为自增的整型值。
实验脚本:
#!/usr/bin/python
# -*- encoding: utf-8 -*- import sqlite3
con = sqlite3.connect(":memory:") # 创建表
con.execute("""
CREATE TABLE todo
(
id INTEGER PRIMARY KEY,
title TEXT
);""") # 创建表:效果相同
'''
con.execute("""
CREATE TABLE todo
(
id INTEGER PRIMARY KEY NOT NULL,
title TEXT
);""")
''' # 插入记录:shopping
con.execute("INSERT INTO todo (title) VALUES ('shopping');") # 插入记录:working
con.execute("INSERT INTO todo (id, title) VALUES (NULL, 'working');") # 查询记录
for row in con.execute("SELECT * FROM todo"):
print row
运行结果:
$ python integer_primary_key_ok.py
(, u'shopping')
(, u'working')
注意:之前看《No autoincrement for Integer Primary key in sqlite3》中有提到“SQLite的自增字段定义为NULL或NOT NULL是有区别的”,根据上面的实验,这个问题好像已经不存在了。
3、关键字AUTOINCREMENT与内部表sqlite_sequence
SQLite中,在INTEGER PRIMARY KEY的基础上添加AUTOINCREMENT后(即INTEGER PRIMARY KEY AUTOINCREMENT),可以在表的整个生命周期内保证“自增字段”的唯一性(create keys that are unique over the lifetime of the table)。
SQLite内部用一个叫作sqlite_sequence的表来保存所有表的自增字段的取值基准(the largest ROWID),如果清空sqlite_sequence的记录,可以实现将所有表的自增字段的取值归零的效果(这种行为具有破坏性,请谨慎使用)。
关于这一主题,更详细的介绍可以参考《How do I create an AUTOINCREMENT field》和《SQLite Autoincrement》
实验脚本:
#!/usr/bin/python
# -*- encoding: utf-8 -*- import sqlite3
con = sqlite3.connect(":memory:") def new_and_show(tbl_name):
"""插入并显示记录"""
# 插入记录到表
con.execute("INSERT INTO " + tbl_name + " (title) VALUES ('shopping');")
# 查询表记录
for row in con.execute("SELECT * FROM " + tbl_name):
print row def clr(tbl_name):
"""清除表记录"""
con.execute("DELETE FROM " + tbl_name) print "--表todo--"
# 1. 创建表
con.execute("""
CREATE TABLE todo
(
id INTEGER PRIMARY KEY,
title TEXT
);""")
# 2. 插入并显示记录
new_and_show("todo")
# 3. 清除表记录
clr("todo")
# 4. 插入并显示记录
new_and_show("todo")
# 5. 清除表记录
clr("todo")
# 6. 插入并显示记录
new_and_show("todo") print "--表todo_auto--"
# 1. 创建表
con.execute("""
CREATE TABLE todo_auto
(
id INTEGER PRIMARY KEY AUTOINCREMENT,
title TEXT
);""")
# 2. 插入并显示记录
new_and_show("todo_auto")
# 3. 清除表记录
clr("todo_auto")
# 4. 插入并显示记录
new_and_show("todo_auto") # 将所有表的自增列都归零
#clr("sqlite_sequence") # 5. 清除表记录
clr("todo_auto")
# 6. 插入并显示记录
new_and_show("todo_auto")
运行结果:
$ python autoincrement_diff.py
--表todo--
(, u'shopping')
(, u'shopping')
(, u'shopping')
--表todo_auto--
(, u'shopping')
(, u'shopping')
(, u'shopping')
如果去掉clr("sqlite_sequence")这一行的注释,则运行结果会变成:
$ python autoincrement_diff.py
--表todo--
(, u'shopping')
(, u'shopping')
(, u'shopping')
--表todo_auto--
(, u'shopping')
(, u'shopping')
(, u'shopping') ## 由于clr("sqlite_sequence")将表todo_auto的自增字段的取值归零,因此这一行又变成了1
另外,SQLite不支持SQL标准语句“TRUNCATE TABLE tbl_name”,只能使用“DELETE FROM tbl_name”来删除表记录,具体可以参考《SQLite清空表并将自增列归零》。
SQLite中的自增关键字:AUTO_INCREMENT、INTEGER PRIMARY KEY与AUTOINCREMENT的更多相关文章
- 如何在SQLite中创建自增字段
SQLite 简单的回答:一个声明为 INTEGER PRIMARY KEY 的字段将自动增加. 这里是详细的答案: 从 SQLite 的 2.3.4 版本开始,如果你将一个表中的一个字段声明为 ...
- sqlite中的自增主键
http://stackoverflow.com/questions/8519936/sqlite-autoincrement-primary-key-questions I'm not sure w ...
- SQLite主键自增需要设置为integer PRIMARY KEY
按照正常的SQL语句,创建一个数据表,并设置主键是这样的语句: ), EventType )) 但使用这种办法,在SQLite中创建的的数据表,如果使用Insert语句插入记录,如下语句: INSER ...
- SQLite3中自增主键相关知识总结,清零的方法、INTEGER PRIMARY KEY AUTOINCREMENT和rowid的使用
这篇文章主要介绍了SQLite3中自增主键相关知识总结,清零的方法.INTEGER PRIMARY KEY AUTOINCREMENT和rowid的使用等,需要的朋友可以参考下 一.SQLite清空表 ...
- (转)Sqlite中INTEGER PRIMARY KEY AUTOINCREMENT和rowid的使用
原文:http://www.cnblogs.com/peida/archive/2008/11/29/1343832.html Sqlite中INTEGER PRIMARY KEY AUTOINCRE ...
- mongdb创建自增主键(primary key)的相关讨论 - Jason.Zhi
根据mongodb官方文档介绍,如果在插入(insert)操作时,没有指定主键id,那么它会自动给插入行自动附上一个主键id.看起来不错,但是详细看看,就会发现这个id值有点复杂. 如下图: mong ...
- SQLite中的增删改查
虽然android提供了sql查询的封装方法,但是理解起来还是麻烦,所以我这里用sql语句来完成工作. 首先是建立一个类,继承SQLiteOpenHelper 这里面会建立一个数据库,并且初始化一个表 ...
- EF6 在 SQLite中使用备忘
== 菜鸟级选手试验在EF6中使用Sqlite,零EF基础,少量Sqlite基础.经过断断续续的很长时间 - _ -! >>连接 1. 安装 使用目前最新版本EF6.1,Sqlite1.0 ...
- 谈数据库索引和Sqlite中索引的使用
要使用索引对数据库的数据操作进行优化,那必须明确几个问题:1.什么是索引2.索引的原理3.索引的优缺点4.什么时候需要使用索引,如何使用围绕这几个问题,来探究索引在数据库操作中所起到的作用. 1.数据 ...
随机推荐
- JSP整理
JSP全称Java Server Pages,是一种动态网页开发技术.它使用JSP标签在HTML网页中插入Java代码.标签通常以<%开头以%>结束. JSP是一种Java servlet ...
- Spine with Unity Mecanim
前言 最近这两天刚刚接触Spine,研究了一下Unity Mecanim Animator如何控制Spine,在此分享记录一下,如有不当之处,请留言指出,欢迎讨论. Unity & Spine ...
- [leetcode-914-X of a Kind in a Deck of Cards]
In a deck of cards, each card has an integer written on it. Return true if and only if you can choos ...
- BVT与冒烟测试
[BVT的释义] BVT的全称是Build Verification Test.可以说这个全称就是BVT的定义了. BVT只验证build构建的成功与失败,不深入测试构建好的build的功能.性能等等 ...
- BZOJ 3489 A simple rmq problem 可持久化KDtree/二维线段树
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3489 题意概述: 给出一个序列,每次询问一个序列区间中仅出现了一次的数字最大是多少,如果 ...
- 团队开发--NABCD
团队成员介绍: 李青:绝对的技术控,团队中扮演“猪”的角色,勤干肯干,是整个团队的主心骨,课上紧跟老师的步伐,下课谨遵老师的指令,课堂效率高,他的编程格言“没有编不出来的程序,只有解决不了的bug”. ...
- 【树上DFS】Tree and Polynomials
http://codeforces.com/gym/101372 D push1[i][k]:所有操作1总共要让节点i下推多少系数k push2[i][k]:所有操作2总共要让节点i上推多少系数k s ...
- 软工1816 · Alpha冲刺(7/10)
团队信息 队名:爸爸饿了 组长博客:here 作业博客:here 组员情况 组员1(组长):王彬 过去两天完成了哪些任务 学会了POSTMAN的使用,对后端已经完成的接口进行了收发消息正确性的验证 推 ...
- 关于虚拟机安装mac os 教程详解
环境搭建 VMware下载 百度云盘下载:链接:http://pan.baidu.com/s/1pK8RcLl 密码:5jc5 Unlocker208 百度云盘下载:链接:http://pan.bai ...
- ORACLE公司传奇历史
ORACLE公司传奇 ORACLE公司之起源 很难想象,ORACLE 公司的这一段传奇居然要从 IBM 公司开始. 1970年的6月,IBM 公司的研究员埃德加·考特 (Edgar Frank Cod ...