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