我用Ado 访问SQLServer 2000. 在我的程序中,会有几个不同的地方都读写数据库。1) 请问我是建立一个全局的连接,如下:
// 程序初始化时建立连接,直到结束
_ConnectionPtr g_pConn;
g_pConn.CreateInstance(__uuidof(Connection));
g_pConn->Open ("Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=DataBaseName;Data Source=ServerName","","",adModeUnknown);然后在其他需要读写数据库的地方建立Recordset,保留g_pConn, 如下:_RecordsetPtr pRS = NULL;
pRS.CreateInstance (__uuidof(Recordset));
pRS->Open ("select * from DataBaseName .. TableName",g_pConn.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);
最后在程序退出时关闭连接:
g_pConn->Close();2)还是单独在每个需要读写数据库的地方都建立连接和Recordset, 读写完关闭连接,下次需要时再建立?如下:// 每次操作都建立起连接和对数据库操作,然后关闭连接
_ConnectionPtr g_pConn;
g_pConn.CreateInstance(__uuidof(Connection));
g_pConn->Open ("Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=DataBaseName;Data Source=ServerName","","",adModeUnknown);_RecordsetPtr pRS = NULL;
pRS.CreateInstance (__uuidof(Recordset));
pRS->Open ("select * from DataBaseName .. TableName",g_pConn.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);g_pConn->Close();请问高手两者哪种比较安全、效率高? 或者有其他更好的方法? 最好能给出代码示例。
非常感谢!