SQLite主键自增需要设置为integer PRIMARY KEY

按照正常的SQL语句,创建一个数据表,并设置主键是这样的语句:

CREATE TABLE [Sample] (EventId int PRIMARY KEY, EventDate timestamp, EventMessage varchar(255), EventType varchar(10))

但使用这种办法,在SQLite中创建的的数据表,如果使用Insert语句插入记录,如下语句:

INSERT INTO Sample VALUES(null, '2013-12-26', 'hello.txt', 'Remove')

那么在实际添加的记录中,主键EventId对应的值不是一个自增的整数,而是一个null值。

经查询得知,在SQLite数据库中,使用int数据类型无法将该主键设置为自增,只有设置为interger数据类型,才能自增。因此,在创建SQLite的自增主键时,应该是下面的SQL语句:

CREATE TABLE [Sample] (EventId integer PRIMARY KEY, EventDate timestamp, EventMessage varchar(255), EventType varchar(10))

注意是:EventId integer PRIMARY KEY

这种语句创建的数据表,在使用Insert语句将null值插入到主键时,会在主键上生成一个自增的整数。

posted @ 2014-01-10 09:36  wusir  阅读(2920)  评论(0编辑  收藏  举报