表名带有空格,无法被运行

_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]

带有空格的话,要用中括号[]括起来。

不仅仅是表名,字段名也是同样的道理。

最好不要给自己找麻烦,如果需要分割可以通过下划线。

在两个单词间加下划线或首字母大写是比较规范的命名方法

中间用下划线啊,你的看下表的命名规范学习下

一般还是不要用空格这类特殊字符啦

带有空格的话,要用中括号[]括起来。

我试过用[]括起来,还是没用。
我这个是特定的表,表名已经定下来了,不能再改了。只能带用空格的表名。

你的表名可以用双引号包起来