1、使用ADO.NET来连接SQL Server数据库
创建一个SqlConnection对象,在它的ConnectionString属性中指定要使用的数据库,然后调用它的Open方法
1
SqlConnection dataConnection = new SqlConnection();
2
string userID = "sa";
3
string password = "test";
4
try
5data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
6
dataConnection.ConnectionString = String.Format("User ID={0};Password={1};Persist Security Info=True;Initial Catalog=Northwind;Data Source=TXC-NOTEBOOK", userID, password);
7
dataConnection.Open(); 2、使用ADO.NET来创建并执行查询
创建一个SqlCommand对象,将它的Connection属性设为一个有效的SqlConnection对象,将它的CommandText设为一个有效的SQL SELECT语句。调用ExecuteReader方法来运行查询并创建一个SqlDataReader对象
1
Console.Write("please enter a customer ID(5 characters):");
2
string customerId = Console.ReadLine();
3data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
4
SqlCommand dataCommand = new SqlCommand();
5
dataCommand.Connection = dataConnection;
6
dataCommand.CommandText = "select OrderID,OrderDate,ShippedDate,ShipName,ShipAddress,ShipCity,ShipCountry " +
7
"from Orders where CustomerID='" + customerId + "'";
8
Console.WriteLine("About to execute:{0}\n\n", dataCommand.CommandText);
9data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
10
SqlDataReader dataReader = dataCommand.ExecuteReader(); 3、使用ADO.NET的SqlDataReader对象来获取数据
使用IsDBNull方法确保数据不是null。如果数据不是null,就用恰当的GetXXX方法(例如GetString和GetInt32等)来获取数据
1
while (dataReader.Read())
2data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
3
int orderId = dataReader.GetInt32(0);
4
if (dataReader.IsDBNull(2))
5data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
6
Console.WriteLine("Order {0} not yet shipped\n\n", orderId);
7
}
8
else
9data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
10data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
11
DateTime orderDate = dataReader.GetDateTime(1);
12
DateTime shipDate = dataReader.GetDateTime(2);
13
string shipName = dataReader.GetString(3);
14
string shipAddress = dataReader.GetString(4);
15
string shipCity = dataReader.GetString(5);
16
string shipCountry = dataReader.GetString(6);
17data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
18
Console.WriteLine("order:{0}\nPlaced:{1}\nShipped:{2}\n" +
19
"To Address:{3}\n{4}\n{5}\n{6}\n\n", orderId, orderDate, shipDate, shipName, shipAddress, shipCity, shipCountry);
20data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
21
}
22data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
23
}
24
dataReader.Close(); 4、定义实体类
定义一个类,在类中为每个列都定义一个public property。在类定义的前一行,附加一个Table attribute。在Table attribute中,指定底层数据库中的表名。在每个public property定义的前一行,都附加一个Column attribute。在Column attribute中,用参数来指定数据库中对应的列的名称、类型以及是否允许为空
1
[Table(Name="Orders")]
2
public class Order
3data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
4
[Column(IsPrimaryKey=true,CanBeNull=false)]
5data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public int OrderID
{ get; set; }
6data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
7
[Column]
8data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string CustomerID
{ get; set; }
9data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
10
[Column]
11data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public DateTime? OrderDate
{ get; set; }
12data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
13
[Column]
14data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public DateTime? ShippedDate
{ get; set; }
15data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
16
[Column]
17data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipName
{ get; set; }
18data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
19
[Column]
20data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipAddress
{ get; set; }
21data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
22
[Column]
23data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipCity
{ get; set; }
24data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
25
[Column]
26data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipCountry
{ get; set; }
27
} 5、使用DLINQ创建并执行查询
创建一个新的DataContext变量,指定一个连接字符串来连接数据库。创建一个Table集合变量,它所基于的实体类必须和你要查询的表对应。定义一个DLINQ查询,它标识要从数据库中获取的数据,并返回实体的一个可枚举的集合。遍历可枚举的集合,即可获取每一行的数据,并对结果进行处理。
1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using System.Data.Linq;
6
using DLINQOrders.model;
7data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
8
namespace DLINQOrders.dao
9data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
10
public class Northwind:DataContext
11data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
12
public Table<Order> Orders;
13
public Northwind(string connectionInfo)
14
: base(connectionInfo)
15data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
16data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
17
}
18
}
19
}
20data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
6
using System.Data.Linq;
7
using System.Data.Linq.Mapping;
8
using System.Data.SqlClient;
9data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
10
namespace DLINQOrders.model
11data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
12
[Table(Name="Orders")]
13
public class Order
14data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
15
[Column(IsPrimaryKey=true,CanBeNull=false)]
16data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public int OrderID
{ get; set; }
17data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
18
[Column]
19data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string CustomerID
{ get; set; }
20data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
21
[Column]
22data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public DateTime? OrderDate
{ get; set; }
23data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
24
[Column]
25data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public DateTime? ShippedDate
{ get; set; }
26data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
27
[Column]
28data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipName
{ get; set; }
29data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
30
[Column]
31data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipAddress
{ get; set; }
32data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
33
[Column]
34data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipCity
{ get; set; }
35data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
36
[Column]
37data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
public string ShipCountry
{ get; set; }
38
}
39
}
40data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using DLINQOrders.dao;
6
using System.Data.SqlClient;
7data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
8
namespace DLINQOrders
9data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
10
class DLINQReport
11data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
12
static void Main(string[] args)
13data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
14
Northwind northwindDB = new Northwind("Data Source=TXC-NOTEBOOK;Initial Catalog=Northwind;Persist Security Info=True;User ID=sa;Password=test");
15
try
16data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
17
Console.WriteLine("Please enter a customer ID(5 characters):");
18
string customerId = Console.ReadLine();
19data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
20
var ordersQuery = from o in northwindDB.Orders
21
where String.Equals(o.CustomerID, customerId)
22
select o;
23
foreach (var order in ordersQuery)
24data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
25
if (order.ShippedDate == null)
26data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
27
Console.WriteLine("Order {0} not yet shipped\n\n", order.OrderID);
28
}
29
else
30data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
31
Console.WriteLine("Order:{0}\nPlaced:{1}\nShipped:{2}\n" +
32
"To Address:{3}\n{4}\n{5}\n{6}\n\n", order.OrderID,
33
order.OrderDate, order.ShippedDate, order.ShipName, order.ShipAddress, order.ShipCity,
34
order.ShipCountry);
35
}
36data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
37
}
38
}
39
catch (SqlException e)
40data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
41
Console.WriteLine("Error accessing the database:{0}", e.Message);
42
}
43
}
44
}
45
}
46data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""