2 timbai2015 timbai2015 于 2015.07.19 08:15 提问

表名带有空格,无法被运行 5C
_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就执行不了了。

请各位大侠,帮忙解决一下。

谢谢!

9个回答

oyljerry
oyljerry   Ds   Rxr 2015.07.19 08:20

表名用[]括起来。
[test table]

guwei4037
guwei4037   Ds   Rxr 2015.07.19 09:33

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

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

lrm928
lrm928   2015.07.19 09:45

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

u014294325
u014294325   2015.07.19 09:49

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

strutce
strutce   Ds   Rxr 2015.07.19 10:24

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

yuke198907
yuke198907   2015.07.19 14:48

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

diaoliwei2
diaoliwei2   Rxr 2015.07.19 19:20

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

timbai2015
timbai2015   2015.07.19 21:07

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

uj2521
uj2521   2015.07.20 16:32

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

Csdn user default icon
上传中...
上传图片
插入图片