c#通过ORM框架访问sqlserver实例
时间: 2023-08-08 10:07:18 浏览: 68
在C#中,常见的ORM框架有Entity Framework、NHibernate、Dapper等,这里以Entity Framework为例,介绍如何访问SQL Server实例。
1. 安装Entity Framework
首先,需要在Visual Studio中安装Entity Framework。打开NuGet包管理器控制台,执行以下命令:
```
Install-Package EntityFramework
```
2. 配置连接字符串
在App.config或Web.config文件中,需要配置SQL Server数据库的连接字符串,例如:
```
<connectionStrings>
<add name="MyDbContext" connectionString="Data Source=localhost;Initial Catalog=test;User ID=root;Password=123456;MultipleActiveResultSets=True;" providerName="System.Data.SqlClient" />
</connectionStrings>
```
其中,`Data Source`指定了SQL Server实例的主机名,`Initial Catalog`指定了数据库名称,`User ID`和`Password`分别为数据库用户名和密码。
3. 创建实体类
使用Entity Framework需要创建实体类,实体类映射到数据库中的表。例如:
```
public class User
{
public int Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
```
其中,`Id`属性为主键,类型为int,`Name`和`Age`属性分别为姓名和年龄,类型为string和int。
4. 创建DbContext类
使用Entity Framework需要创建DbContext类,DbContext类表示数据库上下文,包含了所有实体类与数据库表之间的映射关系。例如:
```
public class MyDbContext : DbContext
{
public DbSet<User> Users { get; set; }
public MyDbContext() : base("name=MyDbContext")
{
}
}
```
其中,`DbSet`表示一个实体集,`Users`属性表示User实体类对应的数据库表。`MyDbContext`类继承自`DbContext`类,调用基类的构造函数时,传入连接字符串的名称。
5. 使用DbContext进行数据库操作
在C#代码中,可以使用DbContext对象进行数据库操作,例如:
```
using (var db = new MyDbContext())
{
var user = new User { Name = "张三", Age = 20 };
db.Users.Add(user);
db.SaveChanges();
}
```
使用`using`语句创建`MyDbContext`对象,然后创建`User`对象并添加到`Users`属性中,最后调用`SaveChanges`方法提交更改。Entity Framework会自动将实体类与数据库表之间的映射关系转换为SQL语句,执行数据库操作。