帮忙挑毛病 C# asp.net “语法错误 (操作符丢失) 在查询表达式''中”错误

下列代码中在names,address,tel这些textbox中只要输入空格,@这样的字符就报错,错误信息是:System.Data.OleDb.OleDbExcept... 下列代码中在names,address,tel这些textbox中只要输入空格,@这样的字符就报错,错误信息是:
System.Data.OleDb.OleDbException: 语法错误 (操作符丢失) 在查询表达式 'ssf sf sf sfsdfds ' 中
表达式时而换成:'12345@qq.com' 或者'2015.3.26 21:16:52'
我都疯掉了!语句没有问题啊 为啥有空格和@就不行???

string str_cnn = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source=";
string str_sourcefile = "~/App_Data/SKDATA.accdb";
OleDbConnection cnn;
OleDbCommand cmd;
OleDbDataReader datar;

string str_sql;
string str_conn = str_cnn + MapPath(str_sourcefile);
cnn = new OleDbConnection(str_conn);
cnn.Open();

str_sql = "INSERT INTO S_SET_shopseting ( [names], address, tel, fax, email, webshop, makeman, makedate ) VALUES ( ";
str_sql += this.names.Text + ", ";
str_sql += this.address.Text + ", ";
str_sql += this.tel.Text + ", ";
str_sql += this.fax.Text + ", ";
str_sql += this.email.Text.ToString() + ", ";
str_sql += this.Onlineshop.Text.ToString() + ", ";
str_sql +="admin"+", ";
string i = DateTime.Now.ToString();
str_sql += i + ")";
cmd = new OleDbCommand(str_sql, cnn);
展开
 我来答
v雪地里的猫
2015-03-26 · TA获得超过864个赞
知道小有建树答主
回答量:401
采纳率:100%
帮助的人:240万
展开全部
OleDbConnection cnn;
OleDbCommand cmd;
string str_conn = "....";
cnn = new OleDbConnection(str_conn);
string str_sql = "insert into s_set_shopseting(names,address,tel,fax,email,webshop,makeman,makedate) values(@names,@address,@tel,@fax,@email,@webshop,@makeman,@makedate)";
cmd = new OleDbCommand(str_sql, cnn);
cmd.Parameters.AddWithValue("@names", this.names.Text);
cmd.Parameters.AddWithValue("@address", this.address.Text);
cmd.Parameters.AddWithValue("@tel", this.fax.Text);
//...
cmd.ExecuteNonQuery();

 你原来是用拼接sql语句的方式,一旦这种拼接方式拼接出来的sql句子有问题,那么就会出异常,甚至是可以注入攻击。

解决办法就是使用参数形式,参考上面代码。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
freeeeeewind
2015-03-26 · TA获得超过1万个赞
知道大有可为答主
回答量:3227
采纳率:94%
帮助的人:1314万
展开全部
str_sql = "INSERT INTO S_SET_shopseting ([names], address, tel, fax, email, webshop, makeman, makedate ) VALUES ";
        str_sql += "('" + this.names.Text  + "', '";
        str_sql += this.address.Text + "', '";
        str_sql += this.tel.Text + "', '";
        str_sql += this.fax.Text + "', '";
        str_sql += this.email.Text.ToString() + "', '";
        str_sql += this.Onlineshop.Text.ToString() + "', '";
        str_sql +="admin"+"', '";
        string i = DateTime.Now.ToString();
        str_sql += i  + "')";

g关键:将与文本对应字段的拼接字符串用单引号引起来

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
我的健康我掌握
2015-03-26 · TA获得超过828个赞
知道小有建树答主
回答量:1757
采纳率:50%
帮助的人:457万
展开全部
字符串两边没有加"
str_sql +=("\""+ this.fax.Text + "\", ");
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式