首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OLEDB单引号错误

OLEDB单引号错误
EN

Stack Overflow用户
提问于 2011-10-18 08:15:40
回答 2查看 2.2K关注 0票数 0

可能重复: OLEDB,编写Excel单元格时不带撇号

我用的是这个代码:

代码语言:javascript
复制
System.Data.OleDb.OleDbConnection MyConnection;
System.Data.OleDb.OleDbCommand myCommand = new System.Data.OleDb.OleDbCommand();
string sql = null;
MyConnection = new System.Data.OleDb.OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0;Data Source='c:\\test_excel.xls';Extended Properties=Excel 8.0;");
MyConnection.Open();
myCommand.Connection = MyConnection;

sql = "CREATE TABLE EmployeeData (Id char(255), Name char(255), BirthDate date)";
myCommand.CommandText = sql;
myCommand.ExecuteNonQuery();

sql = "INSERT INTO EmployeeData (Id, Name, BirthDate) values ('AAA', 'Andrew', '12/4/1955')";
myCommand.CommandText = sql;
myCommand.ExecuteNonQuery();

MyConnection.Close();

代码工作,但我的问题是单引号(见下图)

怎么修?

问题http://www.freeimagehosting.net/newuploads/e32f9.jpg示例

EN

回答 2

Stack Overflow用户

发布于 2011-10-18 08:21:44

您应该始终使用参数化查询。他们是安全的注入,特殊的字符,并使您的代码更加可读性。

代码语言:javascript
复制
OleDbCommand cm = MyConnection.CreateCommand();
cm.CommandText = "INSERT INTO EmployeeData (Id, Name, BirthDate) values (@Id, @Name, @BirthDate)";
cm.Parameters.AddWithValue("@Id", "AAA");
cm.Parameters.AddWithValue("@Name", "'Andrew");
cm.Parameters.AddWithValue("@BirthDate", new DateTime(1955, 4, 12));
cm.ExecuteNonQuery();
票数 0
EN

Stack Overflow用户

发布于 2011-10-18 09:07:39

你有没有试过改变

代码语言:javascript
复制
('AAA', 'Andrew', '12/4/1955') 

转到

代码语言:javascript
复制
("AAA", "Andrew", "12/4/1955")
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7804272

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档