返回列表 发帖

[技术文章] VC++ ADO连接SQLSERVER时连接字符串的模式

一、连接SQL SERVER的第一种连接字串:

是针对数据库身份验证模式为”SQL SERVER 和 windows“而言,

连接字串为:

CString strConn;

strConn = ”Provider = SQLOLEDB.1;\


Persist Security Info = true;\


User ID = sa;\


Password=123456;\


Initial Catalog = tempdb;\


Data Source = 127.0.0.1”;

(包含 6 项,有用户名和密码,数据库名,服务器名(服务器名可以是网络上的,此时是一个IP地址))


二、连接SQL SERVER的第二种连接字串:

       针对身份验证模式为“仅 windows”,


连接字串为:

strConn= “


Provider = SQLOLEDB.1;\


Integrated Security=SSPI;\


Persist Security Info =false;\


Initial Catalog = tempdb;\


Data Source = (local)”;

(包含 5 项,因为已经有windows验证了,所以不再需要用户名和密码,如果是本机的SQL SERVER,那么服务器名可写为(local))


三、连接SQL SERVER的第二种连接字串:


仅针对ODBC的连接方式,


连接字串为:

strConn= “


Provider = SQLOLEDB;\


Server = (local);\


Database = tempdb;\


uid = sa;\


pwd=12345;"


以上三种连接方式,记住任意一种即可,推荐使用第二种


关于连接字串的问题,我们可以借助 udl 文件来处理~~


新创建一个空的txt文件.把扩展名修改为udl就行了.UDL本身是个文本文件.它的主要作用是查看配置好的数据库连接字.先配置好.然后使用记事本打开


eg:我们在桌面创建一个 test.udl 文件,

1.如果要连接SQLserver数据库,【提供程序】选择:

microsoft ole db provider for sql server这一项,

2.【连接】中,服务器名称,选择RICHARDLEE(即本机服务器名称)

如果我们选择windows认证模式,就不用指定用户名和密码了,

【在服务器上选择数据库】这一栏,就填我们在sqlserver中,某个自己想连接的数据库 ,比如 test

再点击【测试连接】,如果连接成功,说明我们的连接字串都是对的~~

3.(我们自己填写的连接字串,在【所有】这一栏中可以看到)

4.把文件的后缀名改为*.txt打开后,就可以发现连接字串了,eg:

[oledb]
; Everything after this line is an OLE DB initstring
Provider=SQLOLEDB.1;Integrated Security=SSPIersist Security Info=False;Initial Catalog=test1;Data Source=RICHARDLEE

5.上面的连接字串就可以用在我们的程序中,比如

hr = m_pConnection.CreateInstance(__uuidof(Connection));

hr = m_pConnection->Open("rovider=SQLOLEDB.1;\

Integrated Security=SSPI;\

Persist Security Info=False;\

Initial Catalog=test1;\

Data Source=(local)","","",adModeUnknown);


(PS:连接字串中,各部分的先后顺序对数据库连接没有影响,即Integrated Security和Persist Security Info,谁在前谁在后,都无所谓)


************************************************************************************************************************

VC_ADO连接SQLSERVER的连接字串和VC-ADO连接ACCESS的连接字串有些不一样的地方~~

1.连接ACCESS时,常用

hr = m_pConnection->Open("rovider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\test1.mdb","","",adModeUnknown);

即,连接字串为"rovider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\test1.mdb"

这里的Data Source=D:\\test1.mdb是ACCESS数据库的名称,除非数据库文件放在了当前工程路径下,否则要写全部路径名,并且要写数据库的后缀名

要注意,是”D:\\“,而不是”D:\“,写成后者,会出错

2.连接SQLSERVER时,

Initial Catalog=test1;这一项表示连接的数据库名,要注意,这里的test1是数据库的名称,不能给他加上路径,也不能加上后缀*.mdf,写成

Initial Catalog=D:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\DATA\test1.mdf;会出错~~

欢迎光临:逐梦论坛

返回列表

Powered by Discuz! 7.2   论坛QQ群:逐梦论坛群

© 2001-2021 Comsenz Inc. 鲁公网安备 37120302000001号