c#,在查询access数据库后,想把结果显示在datagridview中,就报错“标准表达式中数据类型不匹配”。

foreach(string str in indxelist) { OleDbCommand cmd1 = new OleDbCommand(); cmd1.Connection = conn; int i = Convert.ToInt32(str); cmd1.CommandText = string.Format("select doc_ID,doc from doc where doc_ID = '{0}'",i); OleDbDataAdapter adapter = new OleDbDataAdapter(); DataSet ds = new DataSet(); adapter.SelectCommand = cmd1; adapter.Fill(ds); this.dataGridView1.DataSource = ds.Tables[0]; }

你的doc_ID在数据库里是什么类型,如果是数字整形,那就不能在sql里加引号,也就是应该是 where doc_ID={0}",i);追问

我这个是主键,是自动编码的那个序号

追答

那就没错,自动编号是数字

追问

我试试

温馨提示:内容为网友见解,仅供参考
第1个回答  2016-11-23
doc是一个列名吗追问

是的

追答

写法没问题,先在数据库中单独执行 看你那个sql语句没有问题

相似回答
大家正在搜