VS2012-C#-远程连接SQLserver数据库服务器.doc
VS2012C#远程连接SQLserver数据库效劳器
笔记本:系统WIN7;VS2012,;没有安装数据库相关效劳器如SQLserver2005,2008,2012等,
另外一台台式机,且当做效劳器来用吧
台式机:系统winXP,VS2008,数据库效劳器:SQLsever2005
本例实现笔记本在VS2012下远程连接到台式机里的数据库效劳器,采用C#语言;
对于选择不同的数据库效劳器可以依照本方法一样设置
在连接SQLServer2005中,操作不当,经常会报下面的错误:
在建立与效劳器的连接时出错。在连接到SQLServer2005时,在默认的设置下SQLServer不允许进行远程连接可能会导致此失败。(provider:命名管道提供程序,error:40-无法翻开到SQLServer的连接)。
步骤:下面1—8步骤全部在台式机上操作。
对SQLServer2005进行配置。
翻开sqlserver2005的管理器(microsoftsqlservermanagerstudio)
身份验证选择:“Windows身份验证”,点击“连接”,进入。
进入如下
2翻开“对象资源管理器中”的效劳器(4313543D5E24E5\SQLEXPRESS)的属性,接着点击“平安性”,选中“SQLserver和windows身份验证模式”,然后“确定”
3设置一个账号的访问权限,如sa:
在对象资源管理器下〔注意跟上一步的平安性不一样了〕
平安性–》登录名—》sa,双击sa,出现下面界面,
〔1〕在“常规”项下,设置sa的登录密码;〔注意SQLServer2005中,不允许密码设置简单,否那么会通不过。〕
选“默认数据库”,本人自己建立的数据库是RSSI_caiji,也可选择系统自带的
〔2〕然后在“状态”项下设置如下列图所示:选择“授予”,“启动“
点“确定”
4配置SQLsever配置管理器
在SQLsever配置管理器中启动TCP/CP协议,NamedPipes协议如下
5配置SQLServer外围应用效劳器,开启SQL2005远程连接功能
开始-》所有程序-》McrosoftSQLServer2005-配置工具-“SQLServer外围应用配置器”:翻开如下
6选择“效劳和连接的外围应用配置器”-选择DatabaseEngine节点的“远程连接”,选择“本地连接和远程连接”,同时选择“同时使用TCP/IP和namedpipes”。
7然后需要重新启动数据库效劳。
重新启动sqlserver和sqlserverbrowser:最好将sqlserverbrowser启动模式设置为“自动”,以防止电脑重启后需手动再开启sqlserverbrowser
8配置防火墙,关闭防火墙,这样就可以远程连接了。〔网上说还有其他方式,在防火墙例外处添加什么数据库的实例。本人试过无法访问。建议从平安考虑,可以再试验下。〕
下面在笔记本上实现对远程数据库的连接,采用两种方法
第一种方法:
1.翻开VS2012,新建一个解决方案,在解决方案里添加一个SQLserver数据库工程〔名称自己定〕我用database1为例
2在解决方案资源管理器中,点击工程database1的属性
〔1〕在“工程设置”中将“目标平台”改为SQLserver2005如下
〔2〕在“调试”中对于“目标连接字符串”点击“编辑”
显示如下:
〔1〕选择效劳器名:4313543D5E524E5\SQLEXPRESS(台式机数据库效劳器的名称)
〔2〕选择“使用SQLServer身份验证”输入用户名和密码〔自己在台式机中设置的密码〕
〔3〕选择或输入一个数据库名,我自己在台式机上建立的RSSI_caiji〔也可选台式机里数据库效劳器中自带的数据库。〕
显示如下
〔3〕点击“测试连接”,会有测试连接成功的提示,说明成功远程连接上数据库效劳器
〔如果sa无法成功登录,检查sa的状态属性,是否动用了登录〕
第二种方法:
1翻开VS2012,建立一个解决方案,方案里添加一个C#工程,属于控制台应用程序〔这个你因该都会吧,不说了〕
2把Program.cs中的代码换成下面的代码:
usingSystem;
usingSystem.Collections.Generic;
usingSystem.Linq;
usingSystem.Text;