auto_increment引起的“CREATE TABLE 语句中的语法错误”

49 篇文章 0 订阅
37 篇文章 0 订阅

使用环境:

VS2010、C#、Access2007

出错场景:

用SQL语句来动态创建一个表,其中想定义一个字段为主键,并且自动增加

使用代码如下:

private OleDbCommand m_Cmd;  
m_Cmd.CommandText = "create table bookInfo (bookID int not null auto_increment primary key, bookType char(16), nBookNum int)";  
m_Cmd.ExecuteNonQuery(); 
调试时,发现异常: “CREATE TABLE 语句中的语法错误”

查找原因:

这句创建数据表的语句在MySQL中可以正常使用,原本以为是没什么问题的

后来在Access的帮助文档中找关键字的时候,发现了关键字“ AUTOINCREMENT ”

想起来,可能是Access定义了自己的关键字,所以" auto_increment "使用无效

解决办法:

1> 直接把“ auto_increment ”改成" AUTOINCREMENT "

发现还是出现相同的错误提示

2> 只保留" AUTOINCREMENT "关键字

这样是可行的

3> 逐个添加关键字 “primary key”

这样也可行

4> 逐渐添加" int "或者" not null "关键字

这两个关键字,无论使用哪个,都会提示“CREATE TABLE 语句中的语法错误”

因此,感觉应该是跟关键字“ AutoIncrement ”相冲突的。

因此,最后的m_Cmd.CommandText如下:

m_Cmd.CommandText = "create table bookInfo (bookID autoincrement primary key , bookType char(16), booked int)";
大小写是没有关系的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值