_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset;
try
{
m_pConnection.CreateInstance(__uuidof(Connection));
m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Test.MDB","","",adModeUnknown);
}
catch(_com_error e)
{
CString errormessage;
errormessage.Format("conncetion error:%s",e.ErrorMessage());
AfxMessageBox(errormessage);
return;
}
try
{
m_pRecordset.CreateInstance("ADODB.Recordset");
m_pRecordset->Open("SELECT EmployeeID,FirstName,LastName,HireDate,City FROM TEST TABLE WHERE City='London'",
m_pRecordset->Open(_variant_t(sql),
_variant_t((IDispatch*)m_pConnection,true),
adOpenStatic,
adLockOptimistic,
adCmdText);
}
如果 SQL为
SELECT EmployeeID,FirstName,LastName,HireDate,City FROM TESTTABLE WHERE City='London'
就没有问题
但是一旦在把表名字从TESTTABLE ->TEST TABLE, 有空格的表明,那么这个SQL就执行不了了。
请各位大侠,帮忙解决一下。
谢谢!
表名用[]括起来。
[test table]
带有空格的话,要用中括号[]括起来。
不仅仅是表名,字段名也是同样的道理。
最好不要给自己找麻烦,如果需要分割可以通过下划线。
在两个单词间加下划线或首字母大写是比较规范的命名方法
中间用下划线啊,你的看下表的命名规范学习下
一般还是不要用空格这类特殊字符啦
带有空格的话,要用中括号[]括起来。
我试过用[]括起来,还是没用。
我这个是特定的表,表名已经定下来了,不能再改了。只能带用空格的表名。
你的表名可以用双引号包起来