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

使用环境:

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)";
大小写是没有关系的。


你可能感兴趣的:(mysql,C#,table,null,文档,Access)