在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服 务器。请验证实例名称是否正确并且 SQL Server 已配置为允

连接 C#连接Sql server2005,就是连接不上

出现的错误是:

 

在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服

务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命

名管道提供程序, error: 40 - 无法打开到 SQL Server 的连接)

主要问题是默认安装的Sql server2005是端口不是1433,我们要的是1433.


解决方法:

先检查数据库链接是否正确,用户名、密码、链接的数据库的语句等等这些信息是否正确,如果检查了没有问题再看下面的配置。

1.打开Sql server 管理配置器


2.点击SqlExpress的协议,我们要启动所有状态。


3.选择TCP/IP,点击右键,选择属性,我们修改连接数据库的端口地址,非常重要


4.修改三处,第一你查看下跳出来的对话框,里面有好多TCP/IP的端口。我们要找的是三处。


 

5.IP地址 是自己电脑的地址 在TCP端口添加1433,然后选择启动

 

6. IP地址是127.0.0.1的是默认的,也要改掉,如上

 

 

 

 

8.IPALL是否是表示所有端口??反正也要修改下端口地址了。


 

9.重新启动服务,不支持热修改,修改重新启动服务。


 

好了,这就是修改好了端口了。

代码测试:


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;

namespace dbApp
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Hello Word1");
            Program.LinkDB();
            Console.WriteLine("Hello Word3");
            Console.ReadLine();
        }
        static void LinkDB()
        {
            Console.WriteLine("Hello Word2");
            string strConnection = "uid=sa; password=sa; ";
            strConnection += "initial catalog=xTest;Data Source=localhost;";
            strConnection += "Connect Timeout=3";

            try
            {
                SqlConnection objConnection = new SqlConnection(strConnection);
                objConnection.Open();
                Console.WriteLine("连接数据库成功");
                objConnection.Close();
            }
            catch (Exception ex)
            {

                Console.WriteLine(ex.Message);
            }
        }
    }
}

 

 

   连接成功的效果


http://endual.iteye.com/blog/1672861

你可能感兴趣的:(项目开发,Asp.net,C#)