ACCESS的System.Data.OleDb.OleDbException: INSERT INTO 语句的语法错误
一直用的是SQL 数据库,突然改用Access了,使用起来就是没有SQL 顺畅,老是出来些意想不到的错误。今天用Access做的网站程序进行添加数据,调试了一下午,总是异常……
提示ACCESS的System.Data.OleDb.OleDbException: INSERT INTO 语句的语法错误,刚才才在网络上找到了解决的方法,觉得有点不可思议~~在网络上看了看,也是学习ADO.net的人常犯的错误。所以写此日志,以提醒自己
/// <summary>
/// 增加一条数据
/// </summary>
public int Add(Model.article_comment model)
{
int newId;
using (OleDbConnection conn = new OleDbConnection(DbHelperOleDb.connectionString))
{
conn.Open();
using (OleDbTransaction trans = conn.BeginTransaction())
{
try
{
StringBuilder strSql = new StringBuilder();
strSql.Append("insert into " + databaseprefix + "article_comment(");
strSql.Append("channel_id,article_id,parent_id,user_id,user_name,user_ip,content,is_lock,add_time,is_reply,reply_content,reply_time,tel,zhengjian,zhengjianNum,workadd,address,youzhengbm,email,type,title,purpose,describe,newsway,getway)");
strSql.Append(" values (");
strSql.Append("@channel_id,@article_id,@parent_id,@user_id,@user_name,@user_ip,@content,@is_lock,@add_time,@is_reply,@reply_content,@reply_time,@tel,@zhengjian,@zhengjianNum,@workadd,@address,@youzhengbm,@email,@type,@title,@purpose,@describe,@newsway,@getway)"); OleDbParameter[] parameters = {
new OleDbParameter("@channel_id", OleDbType.Integer,),
new OleDbParameter("@article_id", OleDbType.Integer,),
new OleDbParameter("@parent_id", OleDbType.Integer,),
new OleDbParameter("@user_id", OleDbType.Integer,), new OleDbParameter("@user_name", OleDbType.VarChar,),
new OleDbParameter("@user_ip", OleDbType.VarChar,),
new OleDbParameter("@content", OleDbType.VarChar),
new OleDbParameter("@is_lock", OleDbType.Integer,), new OleDbParameter("@add_time", OleDbType.Date),
new OleDbParameter("@is_reply", OleDbType.Integer,),
new OleDbParameter("@reply_content", OleDbType.VarChar),
new OleDbParameter("@reply_time", OleDbType.Date), new OleDbParameter("@tel", OleDbType.VarChar,),
new OleDbParameter("@zhengjian", OleDbType.VarChar,),
new OleDbParameter("@zhengjianNum", OleDbType.VarChar,),
new OleDbParameter("@workadd", OleDbType.VarChar,), new OleDbParameter("@address", OleDbType.VarChar,),
new OleDbParameter("@youzhengbm", OleDbType.VarChar,),
new OleDbParameter("@email", OleDbType.VarChar,),
new OleDbParameter("@type", OleDbType.VarChar,), new OleDbParameter("@title", OleDbType.VarChar,),
new OleDbParameter("@purpose", OleDbType.VarChar,),
new OleDbParameter("@describe", OleDbType.VarChar,),
new OleDbParameter("@newsway", OleDbType.VarChar,),
new OleDbParameter("@getway", OleDbType.VarChar,)};
parameters[].Value = model.channel_id;
parameters[].Value = model.article_id;
parameters[].Value = model.parent_id;
parameters[].Value = model.user_id;
parameters[].Value = model.user_name;
parameters[].Value = model.user_ip;
parameters[].Value = model.content;
parameters[].Value = model.is_lock;
parameters[].Value = model.add_time;
parameters[].Value = model.is_reply;
parameters[].Value = model.reply_content;
parameters[].Value = model.reply_time;
parameters[].Value = model.tel;
parameters[].Value = model.zhengjian;
parameters[].Value = model.zhengjianNum;
parameters[].Value = model.workadd;
parameters[].Value = model.address;
parameters[].Value = model.youzhengbm;
parameters[].Value = model.email;
parameters[].Value = model.type;
parameters[].Value = model.title;
parameters[].Value = model.purpose;
parameters[].Value = model.describe;
parameters[].Value = model.newsway;
parameters[].Value = model.getway ;
DbHelperOleDb.ExecuteSql(strSql.ToString(), parameters);
//取得新插入的ID
newId = GetMaxId(conn, trans);
trans.Commit();
}
catch
{
trans.Rollback();
return -;
}
}
}
return newId;
}
修改后的代码如下:
/// <summary>
/// 增加一条数据
/// </summary>
public int Add(Model.article_comment model)
{
int newId;
using (OleDbConnection conn = new OleDbConnection(DbHelperOleDb.connectionString))
{
conn.Open();
using (OleDbTransaction trans = conn.BeginTransaction())
{
try
{
StringBuilder strSql = new StringBuilder();
strSql.Append("insert into " + databaseprefix + "article_comment(");
strSql.Append("[channel_id],[article_id],[parent_id],[user_id],[user_name],[user_ip],[content],[is_lock],[add_time],[is_reply],[reply_content],[reply_time],[tel],[zhengjian],[zhengjianNum],[workadd],[address],[youzhengbm],[email],[type],[title],[purpose],[describe],[newsway],[getway])");
strSql.Append(" values (");
strSql.Append("@channel_id,@article_id,@parent_id,@user_id,@user_name,@user_ip,@content,@is_lock,@add_time,@is_reply,@reply_content,@reply_time,@tel,@zhengjian,@zhengjianNum,@workadd,@address,@youzhengbm,@email,@type,@title,@purpose,@describe,@newsway,@getway)"); OleDbParameter[] parameters = {
new OleDbParameter("@channel_id", OleDbType.Integer,),
new OleDbParameter("@article_id", OleDbType.Integer,),
new OleDbParameter("@parent_id", OleDbType.Integer,),
new OleDbParameter("@user_id", OleDbType.Integer,), new OleDbParameter("@user_name", OleDbType.VarChar,),
new OleDbParameter("@user_ip", OleDbType.VarChar,),
new OleDbParameter("@content", OleDbType.VarChar),
new OleDbParameter("@is_lock", OleDbType.Integer,), new OleDbParameter("@add_time", OleDbType.Date),
new OleDbParameter("@is_reply", OleDbType.Integer,),
new OleDbParameter("@reply_content", OleDbType.VarChar),
new OleDbParameter("@reply_time", OleDbType.Date), new OleDbParameter("@tel", OleDbType.VarChar,),
new OleDbParameter("@zhengjian", OleDbType.VarChar,),
new OleDbParameter("@zhengjianNum", OleDbType.VarChar,),
new OleDbParameter("@workadd", OleDbType.VarChar,), new OleDbParameter("@address", OleDbType.VarChar,),
new OleDbParameter("@youzhengbm", OleDbType.VarChar,),
new OleDbParameter("@email", OleDbType.VarChar,),
new OleDbParameter("@type", OleDbType.VarChar,), new OleDbParameter("@title", OleDbType.VarChar,),
new OleDbParameter("@purpose", OleDbType.VarChar,),
new OleDbParameter("@describe", OleDbType.VarChar,),
new OleDbParameter("@newsway", OleDbType.VarChar,),
new OleDbParameter("@getway", OleDbType.VarChar,)};
parameters[].Value = model.channel_id;
parameters[].Value = model.article_id;
parameters[].Value = model.parent_id;
parameters[].Value = model.user_id;
parameters[].Value = model.user_name;
parameters[].Value = model.user_ip;
parameters[].Value = model.content;
parameters[].Value = model.is_lock;
parameters[].Value = model.add_time;
parameters[].Value = model.is_reply;
parameters[].Value = model.reply_content;
parameters[].Value = model.reply_time;
parameters[].Value = model.tel;
parameters[].Value = model.zhengjian;
parameters[].Value = model.zhengjianNum;
parameters[].Value = model.workadd;
parameters[].Value = model.address;
parameters[].Value = model.youzhengbm;
parameters[].Value = model.email;
parameters[].Value = model.type;
parameters[].Value = model.title;
parameters[].Value = model.purpose;
parameters[].Value = model.describe;
parameters[].Value = model.newsway;
parameters[].Value = model.getway ;
DbHelperOleDb.ExecuteSql(strSql.ToString(), parameters);
//取得新插入的ID
newId = GetMaxId(conn, trans);
trans.Commit();
}
catch
{
trans.Rollback();
return -;
}
}
}
return newId;
}
总结:在System.Data.oleDb 命名空间下使用SQL语句插入内容要在字段名与表名加“[]”
ACCESS的System.Data.OleDb.OleDbException: INSERT INTO 语句的语法错误的更多相关文章
- 向ACCESS数据库中的表导入EXCEL表,在 System.Data.OleDb.OleDbException 中第一次偶然出现的“System.Data.dll”类型的异常
向ACCESS数据库中的表导入EXCEL表,EXCEL表Sheet1中与ACCESS数据库表中的关键字对应的列的值,不能与数据库中表的主键项值重复,不然就会出现 在 System.Data.OleDb ...
- access数据库频繁读取操作会出现 System.Data.OleDb.OleDbException 的异常解决
asp.net access数据库 本来想着打开一个access数据库连接后,不关闭,下次操作数据了,直接拿来用,谁知道连着测试64次后(大概这么多次),就会出现System.Data.OleDb.O ...
- System.Data.OleDb.OleDbException: 未指定的错误的解决方法
异常详细信息: System.Data.OleDb.OleDbException: 未指定的错误 这个错误是access数据库特有的错误,当access频繁读取或操作过多的时候就会发生这个错误,微软官 ...
- 关于“System.Data.OleDb.OleDbException,外部数据库驱动程序 (1) 中的意外错误。”的解决方案
网站之前运行一直很正常,但有一次用户在导入格式为xls的excel文件,发生了错误,跟踪错误后抛出如下的异常: 错误提示: 未处理System.Data.OleDb.OleDbException HR ...
- [Microsoft][ODBC Microsoft Access Driver] INSERT INTO 语句的语法错误。
遇到的情景: sta.executeUpdate("insert into 表1(longitude,latitude,time) values("+a[0]+",&qu ...
- 操作ACCESS数据库,报INSERT INTO 语句的语法错误
错误类型:Microsoft JET Database Engine (0x80040E14)INSERT INTO 语句的语法错误. 有时候非常郁闷,明明看起来自己的语句没错,为什么还是报错呢?其实 ...
- INSERT INTO 语句的语法错误【 OLE报错,office终端执行SQL没有问题】
表名,字段在代码执行之前一定要进行" [ 字段.表名 ] "中括号包裹,不然会报INSERT INTO 语句的语法错误! office终端没有报错的原因,应该是office在执行之 ...
- Insert Into 语句的语法错误
错误示意: 一开始程序是: 改正: 一条很简单的插入语句竟然会报错,然而直接在数据库的查询中执行中却没有问题,这个问题困扰了不少时间. 数据库使用的是ACCESS,INSERT INTO语句为inse ...
- 问题.NETSystem.Data.OleDb.OleDbException 操作必须使用一个可更新的查询
问题:System.Data.OleDb.OleDbException 操作必须使用一个可更新的查询 问题现象:用asp.net连access数据库,查询可以,插入数据报错.在.NET中F5可以使用方 ...
随机推荐
- windows 32位系统中进程最大可用内存空间为3GB (转)
http://msdn.microsoft.com/zh-cn/library/ms189334.aspx 进程地址空间 所有 32 位应用程序都有 4 GB 的进程地址空间(32 位地址最多可以映射 ...
- 近期最久未使用页面淘汰算法———LRU算法(java实现)
请珍惜小编劳动成果,该文章为小编原创,转载请注明出处. LRU算法,即Last Recently Used ---选择最后一次訪问时间距离当前时间最长的一页并淘汰之--即淘汰最长时间没有使用的页 依照 ...
- DLX舞蹈链 hdu5046
题意: 在N个城市选出K个城市,建飞机场(1 ≤ N ≤ 60,1 ≤ K ≤ N),N个城市给出坐标,选择这K个机场,使得从城市到距离自己最近的机场的 最大的距离 最小. 输出这个最小值. 思路: ...
- handler looper 和 线程
Handler的概念: 顾名思义,handler在英语中是“操作着,处理者的意思”,而官方的文档给出的概念是,handler允许你发送或者处理Message对象或者Runable对象,这两个对象都是 ...
- 你真的会使用SQL Server的备份还原功能吗?之二:主要备份类型
假设在下面几个时间段中,一个数据库积累插入了如下数据: 1.完整数据库备份 故名思意,完整数据库备份包括完整的数据库信息.它包括数据库的数据文件和备份结尾的部份活动事务日志. 完整备份基本语法如下: ...
- javascript 变量解析
1.JavaScript中,你可以在函数的任何位置声明多个var语句,并且它们就好像是在函数顶部声明一样发挥作用,这种行为称为 hoisting(悬置/置顶解析/预解析).当你使用了一个变量,然后不久 ...
- data URI scheme
优化网页效能,首要的任务是尽量减少HTTP请求(http request)的次数,例如把多个JavaScript文档合并,多个CSS文件合并等等.此外,还有有一种 data URL 的方法,可以直接把 ...
- java中set和get方法的理解
对于JAVA初学者来说,set和get这两个方法似乎已经很熟悉了,这两个方法是JAVA变成中的基本用法,也是出现频率相当高的两个方法. 为了让JAVA初学者能更好的理解这两个方法的使用和意义,今天笔者 ...
- selenium 一个简单的流程
在整个自动化测试过程中需要分为及部分: 1.初始化 2.结束 3.异常处理 4.截图 5.对弹窗的处理 6.测试用例 整个过程中需要包括 ...
- GridView格式化
<asp:TemplateColumn HeaderText="进出境运输方式"> <ItemTemplate> <%# Eval(" ...