我用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();请问高手两者哪种比较安全、效率高? 或者有其他更好的方法? 最好能给出代码示例。
非常感谢!
// 程序初始化时建立连接,直到结束
_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();请问高手两者哪种比较安全、效率高? 或者有其他更好的方法? 最好能给出代码示例。
非常感谢!
解决方案 »
- 如何改变列表框某一项选中时的高亮颜色
- ISAPI和WebService有什么区别?
- 编译MTK平台MMI程序的工具包是什么?
- 请问在WTL中如何修改界面lable 文本的大小及颜色风格等??
- CListCtrl 问题
- 如何对server和client同时进行调试?
- 我想用Socket方式通过代理服务器访问外网(如news.sina.com.cn),请问怎样给定代理服务器所需要的用户名和密码?
- 用InstallShield怎样来做一个驱动安装
- 如个改变窗口滚动条的颜色或把滚动条设为自定的图形
- 我在一个对话框上加入一个RICH EDIT控件,为何该对话框不显示了?
- Windows 系统的响应时间是多少?用VxD是否能快些?
- …………………………关于CListCtrl的问题……………………
这样:
一不管你在什么地方实例化这个类,都不用担心它连接和关闭的问题。
二你只在类的造构和析构函数打开和关闭连接,效率也较高。