最近迷上c#,下午装好了SQL server management studio Express
附加经典的northwind数据库
然后用下面一段代码测试
1using System;
2using System.Collections.Generic;
3using System.Text;
4using System.Data;
5using System.Data.Sql;
6using System.Data.SqlClient;
7
8namespace ODBCDataBaseTest
9{
10 class Program
11 {
12 static void Main(string[] args)
13 {
14 //sql链接
15 string connectString = @"Server=(local);Integrated Security=SSPI;DataBase=Northwind";
16
17 string queryString = "select * from Customers";
18
19 using (SqlConnection sqlConnect = new SqlConnection(connectString))
20 {
21
22 SqlDataAdapter odAdapter = new SqlDataAdapter(queryString, sqlConnect);
23 DataSet ds = new DataSet();
24 DataTable dt = new DataTable();
25
26
27 odAdapter.Fill(ds, "Info");
28
29 dt = ds.Tables[0];
30
31 Console.WriteLine("Successfully");
32
33 foreach (DataRow dr in dt.Rows)
34 {
35 Console.WriteLine(dr[0] + "\t" + dr[1] + "\t" + dr[2] + "\t" + dr[3]
36 + "\t" + dr[4]);
37 }
38
39 }
40 Console.ReadLine();
41 }
42 }
43}
2using System.Collections.Generic;
3using System.Text;
4using System.Data;
5using System.Data.Sql;
6using System.Data.SqlClient;
7
8namespace ODBCDataBaseTest
9{
10 class Program
11 {
12 static void Main(string[] args)
13 {
14 //sql链接
15 string connectString = @"Server=(local);Integrated Security=SSPI;DataBase=Northwind";
16
17 string queryString = "select * from Customers";
18
19 using (SqlConnection sqlConnect = new SqlConnection(connectString))
20 {
21
22 SqlDataAdapter odAdapter = new SqlDataAdapter(queryString, sqlConnect);
23 DataSet ds = new DataSet();
24 DataTable dt = new DataTable();
25
26
27 odAdapter.Fill(ds, "Info");
28
29 dt = ds.Tables[0];
30
31 Console.WriteLine("Successfully");
32
33 foreach (DataRow dr in dt.Rows)
34 {
35 Console.WriteLine(dr[0] + "\t" + dr[1] + "\t" + dr[2] + "\t" + dr[3]
36 + "\t" + dr[4]);
37 }
38
39 }
40 Console.ReadLine();
41 }
42 }
43}
发生异常 没有打开远程链接,打开sql server外围配置器 发现确实启用了 named pipes 和 tcp/ip链接 我又重启了 database engine下面的服务
再次运行上面的代码 重新测试一下 还是不行。。。郁闷了。。。
我在命令行(运行-cmd)里输入 netstat 发现没有ms-sql端口,原来如此 哈哈
打开 sql server configuration management选择sqlexpress协议 里面的tcp/ip协议
在分页里面 吧ip1--ip3的动态端口全部设置为0 并且把tcp端口设置为1433(这样做会不会狠了点 副作用不知道)
重新运行上面的代码 通过。。
ps:为啥微软要默认关闭远程链接呢?不懂