auto_increment引起的“CREATE TABLE 语句中的语法错误”
来源:互联网 发布:淘宝电脑配置 编辑:程序博客网 时间:2024/05/17 03:54
使用环境:
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)";大小写是没有关系的。
- auto_increment引起的“CREATE TABLE 语句中的语法错误”
- .net连接access数据库 关键字引起的 语句的语法错误
- 关于Create table中的using index语句
- 关于Create table中的using index语句
- MySQL Create Table语句
- SQL CREATE TABLE 语句
- CREATE TABLE 语句
- SQL CREATE TABLE 语句
- SQL CREATE TABLE 语句
- SQL CREATE TABLE 语句
- SQL CREATE TABLE 语句
- SQL语句CREATE TABLE
- CREATE TABLE 语句
- SQL CREATE TABLE 语句
- SQL高级语句-CREATE TABLE 用于创建数据库中的表
- UPDATE 语句的语法错误
- SQL语句的语法错误
- Create Table中的秘密!
- java:nextLine()与next()
- gcc编译选项
- Esxi 5 中安装CentOS6.2 找不到网卡
- C/C++的经典书籍
- javascript一些常用笔记
- auto_increment引起的“CREATE TABLE 语句中的语法错误”
- 联动下拉框 jquery插件(三)
- HTTP 获取网页内容 HttpURLConnection与HttpClient
- AjaxFileUploader上传插件 兼容性好 Ie Chrome Firefox
- MS 多声道音频数据和 WAVE 文件
- 录音文件按年月日分开存放的方法
- 第5周实验报告任务2(修改)
- 汉字转换为拼音以及缩写(javascript)
- android TextView 的圆角背景