[EF]使用EF简单增删改查

目录

认识EF

添加数据

删除数据

修改数据

查询数据

总结

认识EF

ADO.NET Entity Framework 是微软以ADO.NET为基础所发展出来的对象关系对伊(O/R Mapping)解决方案,早起被称为ObjectSpage,最新版本EF6。

实体框架Entity Framework是ADO.NET中的一组支持面向数据的软件应用程序的技术。是微软的一个ORM框架。

什么是O/R Mapping

广义上,ORM指的是面向对象模型和关系数据库的数据结构之间的相互转换。

狭义上,ORM可以被认为是,基于关系数据库的数据存储,实现一个虚拟的面向对象的数据访问接口。理想情况下,基于这样一个面向对象的接口,持久化一个OO对象应该不需要了解任何关系型数据存储数据的实现细节。

添加数据

测试用数据库

 1 USE [Wolfy.Shop]
 2 GO
 3
 4 /****** Object:  Table [dbo].[TB_Customer]    Script Date: 2014/7/29 20:01:56 ******/
 5 SET ANSI_NULLS ON
 6 GO
 7
 8 SET QUOTED_IDENTIFIER ON
 9 GO
10
11 CREATE TABLE [dbo].[TB_Customer](
12     [ID] [uniqueidentifier] NOT NULL,
13     [Name] [nvarchar](32) NULL,
14     [Address] [nvarchar](100) NULL,
15     [Gender] [bit] NULL,
16  CONSTRAINT [PK_CustomerID] PRIMARY KEY CLUSTERED
17 (
18     [ID] ASC
19 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
20 ) ON [PRIMARY]
21
22 GO

 1 USE [Wolfy.Shop]
 2 GO
 3
 4 /****** Object:  Table [dbo].[TB_Order]    Script Date: 2014/7/29 20:02:47 ******/
 5 SET ANSI_NULLS ON
 6 GO
 7
 8 SET QUOTED_IDENTIFIER ON
 9 GO
10
11 CREATE TABLE [dbo].[TB_Order](
12     [ID] [int] NOT NULL,
13     [OrderName] [nvarchar](1000) NULL,
14     [CreateDate] [datetime] NULL,
15     [customerId] [uniqueidentifier] NULL,
16  CONSTRAINT [PK_TB_Order] PRIMARY KEY CLUSTERED
17 (
18     [ID] ASC
19 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
20 ) ON [PRIMARY]
21
22 GO
23
24 ALTER TABLE [dbo].[TB_Order]  WITH CHECK ADD  CONSTRAINT [FK_Customer_Order] FOREIGN KEY([customerId])
25 REFERENCES [dbo].[TB_Customer] ([ID])
26 GO
27
28 ALTER TABLE [dbo].[TB_Order] CHECK CONSTRAINT [FK_Customer_Order]
29 GO

工具VS2013,SQL SERVER2012
在使用EF的时候发现,跟之前的版本差别还是挺大的,有些方法的名字都改了。这里记录一下,使用的时候方便查找吧。

测试页面

 1 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AddCustomer.aspx.cs" Inherits="Wofly.EFDemo.AddCustomer" %>
 2
 3 <!DOCTYPE html>
 4
 5 <html xmlns="http://www.w3.org/1999/xhtml">
 6 <head runat="server">
 7     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 8     <title></title>
 9 </head>
10 <body>
11     <form id="form1" runat="server">
12         <div>
13             <asp:Button Text="添加" CommandArgument="add" runat="server" ID="btnAdd" OnClick="btnAdd_Click" />
14             <table>
15                 <tr>
16                     <td>用户名:</td>
17                     <td>
18                         <asp:TextBox runat="server" ID="txtUserName" ClientIDMode="Static" /></td>
19                 </tr>
20                 <tr>
21                     <td>用户地址:</td>
22                     <td>
23                         <asp:TextBox runat="server" ID="txtAddress" ClientIDMode="Static" /></td>
24                 </tr>
25                 <tr>
26                     <td>性别:</td>
27                     <td>
28                         <asp:RadioButton runat="server" Checked="true" ID="rdbMan" Text="男" GroupName="gender" />
29                         <asp:RadioButton GroupName="gender" runat="server" ID="rdbFemale" Text="女" />
30                     </td>
31                 </tr>
32             </table>
33             <asp:Repeater runat="server" ID="rptCustomerList">
34                 <HeaderTemplate>
35                     <table>
36                         <tr>
37                             <th>序号</th>
38                             <th>用户名</th>
39                             <th>地址</th>
40                             <th>性别</th>
41                             <th>操作</th>
42                         </tr>
43                 </HeaderTemplate>
44                 <ItemTemplate>
45                     <tr>
46                         <td><%#Container.ItemIndex+1 %></td>
47                         <td><%#Eval("Name") %></td>
48                         <td><%#Eval("Address") %></td>
49                         <td><%#Convert.ToBoolean(Eval("Gender"))==true?"男":"女" %></td>
50                         <td>
51                             <asp:LinkButton Text="编辑" runat="server" OnClick="lnkEdit_Click" CommandName="Edit" CommandArgument='<%#Eval("ID") %>' ID="lnkEdit" /><asp:LinkButton Text="删除" runat="server" OnClick="lnkEdit_Click" ID="lnkDelete" CommandName="Delete" CommandArgument='<%#Eval("ID") %>' /></td>
52                     </tr>
53                 </ItemTemplate>
54                 <FooterTemplate>
55                     </table>
56                 </FooterTemplate>
57             </asp:Repeater>
58         </div>
59     </form>
60 </body>
61 </html>

增加用户

1                ShopEntities shopEntities = new ShopEntities();
2                 TB_Customer tb_CustomerAdd = new TB_Customer() { ID = Guid.NewGuid(), Name = txtUserName.Text, Address = txtAddress.Text, Gender = rdbMan.Checked ? true : false };
3                 shopEntities.TB_Customer.Add(tb_CustomerAdd);
4                 int intResult = shopEntities.SaveChanges();
5                 if (intResult > 0)
6                 {
7                     DataInit();
8                 }

 

删除数据

1                    shopEntities.TB_Customer.Remove(tb_Customer);
2                     if (shopEntities.SaveChanges() > 0)
3                     {
4                         this.DataInit();
5                     }

 

修改数据

 1                 ShopEntities shopEntities = new ShopEntities();
 2                 var customer = from c in shopEntities.TB_Customer
 3                                where c.ID == new Guid(btn.CommandArgument)
 4                                select c;
 5                 TB_Customer tb_CustomerUpdate = customer.FirstOrDefault<TB_Customer>();
 6                 //将 对象 添加到 EF中
 7                 tb_CustomerUpdate.Name = txtUserName.Text;
 8                 tb_CustomerUpdate.Address = txtAddress.Text;
 9                 tb_CustomerUpdate.Gender = rdbMan.Checked ? true : false;
10                 //是否修改
11                 shopEntities.Entry<TB_Customer>(tb_CustomerUpdate).State = System.Data.EntityState.Modified;
12                 //一次性 生成sql语句到数据库执行
13                 shopEntities.SaveChanges();

 

查询数据

1         private void DataInit()
2         {
3             ShopEntities shopEntities = new ShopEntities();
4             var customers = from c in shopEntities.TB_Customer
5                             select c;
6             this.rptCustomerList.DataSource = customers.ToList();
7             this.rptCustomerList.DataBind();
8         }

 

总结

新技术更新可真快,这里只是记录增删改查的方法,也没具体描述,只是影响中感觉跟ef4差别很大。这里记录一下,使用起来的时候,希望能快速上手。

博客地址: http://www.cnblogs.com/wolf-sun/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。
如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步!
再次感谢您耐心的读完本篇文章。

转载:http://www.cnblogs.com/wolf-sun/p/3873859.html

时间: 2025-01-23 20:23:01

[EF]使用EF简单增删改查的相关文章

mybatis generator 配置 反向生成Entity简单增删改查(推荐)_java

mybatis generator 配置 反向生成Entity简单增删改查实例代码如下所示: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd

如何整合ssh,用这个框架配合mysql数据库做简单增删改查

问题描述 我要详细的流程.有的人速度.越简单,越详细越好. 解决方案 解决方案二:找个例子研究去

PYTHON中简单的文件增删改查处理

快一个月木有更新了,在这段时间内,博主除了忙工作外,就一直在研究python编程,据圈内朋友闲聊,python应该是未来一个运维攻城狮除了shell以外必备的LINUX脚本语言,所以就硬着头皮,按照老男孩的python视频讲座,把自己的研究成果贴出来,目前还没学完,期待老男孩的讲座更加给力些. PS: 1.老男孩的python视频讲座很不错,希望能继续免费下去... 2.博主编程很烂,有什么地方有问题,还请多多指教... 3.最近买了本PYTHON核心编程,啃书ing... 系统环境: Ubun

谁有最简单的增删改查程序啊,发过来研究研究呗

问题描述 以前学的是ASP,最近转到.net上,看了一些书还是有些迷茫,还求能给个最简单的增删改查或者新闻发布系统研究一下,我用的是VS2008 解决方案 解决方案二:http://topic.csdn.net/u/20110414/10/06526263-9e0d-491f-b963-7ae0afd1f7e4.html解决方案三:简单增删改查:

javascript js 操作数组 增删改查的简单实现_javascript技巧

函数定义 Array.prototype.indexOf = function(val) { for (var i = 0; i < this.length; i++) { if (this[i] == val) return i; } return -1; }; Array.prototype.remove = function(val) { var index = this.indexOf(val); if (index > -1) { this.splice(index, 1); } }

MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

[正文] 首先需要回顾一下上一篇文章中的内容:MySQL数据库学习笔记(八)----JDBC入门及简单增删改数据库的操作 一.ResultSet接口的介绍: 对数据库的查询操作,一般需要返回查询结果,在程序中,JDBC为我们提供了ResultSet接口来专门处理查询结果集. Statement通过以下方法执行一个查询操作: ResultSet executeQuery(String sql) throws SQLException  单词Query就是查询的意思.函数的返回类型是ResultSe

EF里单个实体的增查改删以及主从表关联数据的各种增删改查

原文:EF里单个实体的增查改删以及主从表关联数据的各种增删改查 本文目录 EF对单个实体的增查改删 增加单个实体 查询单个实体 修改单个实体 删除单个实体 EF里主从表关联数据的各种增删改查 增加(增加从表数据.增加主从表数据) 查询(查询导航属性为集合.查询导航属性为单个对象) 修改(修改从表的外键) 删除(删除主从表关系.删除主表数据.删除主从表数据.修改从表数据外键) 补充内容 SaveChanges方法提交多次操作 DbSet.Add方法返回当前实体 源码和系列文章导航 注:本章节多次演

构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(5)-EF增删改查by糟糕的代码

原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(5)-EF增删改查by糟糕的代码 上一讲我们创建了一系列的解决方案,我们通过一个例子来看看层与层之间的关系. 我们把Controllers分离出来了BLL层和DAL层 BLL专注于业务上的处理 DAL专注于数据访问层的处理 而Controller跟清楚的与View交互 我们上一讲已经在EF添加了一个实体SysSample 下面我们创建IDAL,DAL,IBLL,BLL的代码吧 using App.Mod

asp net 管理系统-求一个简单的asp的web页面管理系统,只要求实现增删改查就行

问题描述 求一个简单的asp的web页面管理系统,只要求实现增删改查就行 求大神发一个初学者的管理给我,顺带讲解讲解,实在做不出来....................qq:732796124