关于连接数据库的问题

haluo 2004-01-06 09:20:16
我用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();



请问高手两者哪种比较安全、效率高? 或者有其他更好的方法? 最好能给出代码示例。
非常感谢!

...全文
38 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Kitfox AI 2004-01-06
  • 打赏
  • 举报
回复
我觉得是,建一个类,封装ado的读写操作。在类的构造和析构函数里建立/关闭连接。
这样:
一不管你在什么地方实例化这个类,都不用担心它连接和关闭的问题。
二你只在类的造构和析构函数打开和关闭连接,效率也较高。

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧