1.在数据库中新建两张测试表

创建用户表

use eftest
go
if exists(select * from sysobjects where name='UserInfo')
drop table UserInfo
create table UserInfo(
ID int identity(1,1) primary key,
UserName nvarchar(100) not null,
Sex char(1) default '男',
age int
)
go

创建订单表

use eftest
go
if exists (select * from sysobjects where name='OrderInfo')
drop table OrderInfo
create table OrderInfo
(
ID int identity(1,1) primary key,
UserID int not null ,
ThinName nvarchar(100) not null
)
go alter table OrderInfo
add constraint OrderInfo_fk_UserInfo foreign key(UserID) references UserInfo(ID)
select OrderInfo_fk_UserInfo

生成的ef中的几个重要文件

以及两个相关的类

EF 基础知识:

集合版实现ef的增加、修改、删除、查询

EfTestEntities content=new EfTestEntities();
var userInfo = new UserInfo
{
UserName = "admin1",age = ,Sex = "男"
};
content.UserInfo.Add(userInfo);
//通过主键查询记录
UserInfo userinfo=content.UserInfo.Find();
//修改数据
userinfo.UserName = "test123";
//删除记录,请注意,在调用此方法之前,该实体必须以另一种状态存在于该上下文中。
//即:该对象不能是自己实例创建的对象,必须是先查再删
content.UserInfo.Remove(userinfo); content.SaveChanges();

状态版实现增删改查

首先是来看DbContext中的两个方法

1.传如一个实体,返回一个被跟踪的实体(为什么在上面在删除的时候,如果删除的实体没处于上下文中,就会报错,而这个状态就是在这生成的,因为增加,修改,删除的实现,并不是马上就执行的,只是你在操作的时候,先把上下文对象的状态进行了改变,在最后提交时才去按照上下文生成sql语句执行

            //增加,通过更改实体的状态实现,上面集合的实现本质上也是这种是实现
context.Entry(userInfo).State = EntityState.Added;
context.SaveChanges(); //修改,建议使用,因为集合必须手动建立上下文跟踪后才能操作,而这个直接通过上下下文跟踪更直接
//但这个将通过主键修改对象所有的字段,比如下面没设置age和sex,那么将改为null
var useri = new UserInfo { ID = , UserName = "oldboy" };
context.Entry(useri).State = EntityState.Modified;
context.SaveChanges(); //同理删除也一样
var useri = new UserInfo { ID = , UserName = "oldboy" };
context.Entry(useri).State = EntityState.Deleted;
context.SaveChanges(); //状态版还能修改某一个列,而集合版修改必须的先查整个对象再修改
var useri = new UserInfo { ID = };
context.UserInfo.Attach(useri); //将对象加入上下文,默认为无状态(即不新增、也不修改、也不删除)
context.Entry(useri).Property("UserName").CurrentValue = "yearboy";
context.Entry(useri).Property("UserName").IsModified = true;
context.SaveChanges();
//状态

在DataContext中提供了Entity方法让我们来操作实体的状态

 /// <summary>
/// Gets a <see cref="DbEntityEntry{T}" /> object for the given entity providing access to
/// information about the entity and the ability to perform actions on the entity.
/// </summary>
/// <typeparam name="TEntity"> The type of the entity. </typeparam>
/// <param name="entity"> The entity. </param>
/// <returns> An entry for the entity. </returns>
public DbEntityEntry<TEntity> Entry<TEntity>(TEntity entity) where TEntity : class
{
Check.NotNull(entity, "entity"); return new DbEntityEntry<TEntity>(new InternalEntityEntry(InternalContext, entity));
} /// <summary>
/// Gets a <see cref="DbEntityEntry" /> object for the given entity providing access to
/// information about the entity and the ability to perform actions on the entity.
/// </summary>
/// <param name="entity"> The entity. </param>
/// <returns> An entry for the entity. </returns>
public DbEntityEntry Entry(object entity)
{
Check.NotNull(entity, "entity"); return new DbEntityEntry(new InternalEntityEntry(InternalContext, entity));
}
 public virtual DbSet<TEntity> Set<TEntity>() where TEntity : class
{
return (DbSet<TEntity>)InternalContext.Set<TEntity>();
} /// <summary>
/// Returns a non-generic <see cref="DbSet"/> instance for access to entities of the given type in the context
/// and the underlying store.
/// </summary>
/// <param name="entityType"> The type of entity for which a set should be returned. </param>
/// <returns> A set for the given entity type. </returns>
/// <remarks>
/// Note that Entity Framework requires that this method return the same instance each time that it is called
/// for a given context instance and entity type. Also, the generic <see cref="DbSet{TEntity}"/> returned by the
/// <see cref="Set"/> method must wrap the same underlying query and set of entities. These invariants must
/// be maintained if this method is overridden for anything other than creating test doubles for unit testing.
/// See the <see cref="DbSet"/> class for more details.
/// </remarks>
[SuppressMessage("Microsoft.Naming", "CA1716:IdentifiersShouldNotMatchKeywords", MessageId = "Set")]
public virtual DbSet Set(Type entityType)
{
Check.NotNull(entityType, "entityType"); return (DbSet)InternalContext.Set(entityType);
}

两种语法的查询

查询语法

DbContext context1=new EfTestEntities();
//获取UserInfo的集合,等同 EfTestEntities 中的UserInfo集合
DbSet<UserInfo> users = context1.Set<UserInfo>();
var result = from info in users
where info.ID > && info.age != null
select info.OrderInfo;
Console.Write(result.Count());
 DbContext context1=new EfTestEntities();
//获取UserInfo的集合,等同 EfTestEntities 中的UserInfo集合
DbSet<UserInfo> users = context1.Set<UserInfo>();
var result = from info in context.UserInfo
join orde in context.OrderInfo on info.ID equals orde.UserID select info;
Console.WriteLine(result); var result1 = from info in context.UserInfo
from orde in info.OrderInfo select info;
Console.WriteLine(result1);

 var result1 = from info in context.UserInfo
from orde in info.OrderInfo
select new //new 新类
{
id = info.ID,
name = info.UserName
};

方法语法

var tt = context.UserInfo.Where(c => c.ID > 14).Select(c => new {c.ID, c.UserName});

  //分页
var re = context.UserInfo.
Where(c => c.ID > ).
OrderByDescending(c => c.ID)
.Skip().Take()
.Select(c => c);

Sql Server 表创建以及Ef浅谈的更多相关文章

  1. 05Microsoft SQL Server 表创建,查看,修改及删除

    Microsoft SQL Server 表创建,查看,修改及删除 创建表 创建普通表 use 数据库名称 go create table 表名称( 列1 ) not null, 列2 ) not n ...

  2. SQL server 表中如何创建索引?

    SQL server 表中如何创建索引?看个示例,你就会了 use master goif db_id(N'zhangxu')is not nulldrop database zhangxugocre ...

  3. SQL Server表分区的NULL值问题

    SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,但是本人觉得已经够用了 虽然MySQL支持四种分区类型:RANGE分区.LIST分区.HASH分区 ...

  4. SQL Server 表变量和临时表的区别

    SQL Server 表变量和临时表的区别 一.表变量 表变量在SQL Server 2000中首次被引入.表变量的具体定义包括列定义,列名,数据类型和约束.而在表变量中可以使用的约束包括主键约束,唯 ...

  5. [转载]在SQL Server 中,如何实现DBF文件和SQL Server表之间的导入或者导出?

    原来使用SQL Server 2000数据库,通过DTS工具很方便地在SQL Server和DBF文件之间进行数据的导入和导出,现在安装了SQL Server2005之后,发现其提供的“SQL Ser ...

  6. SQL Server表分区【转】

    转自:http://www.cnblogs.com/knowledgesea/p/3696912.html SQL Server表分区   什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在 ...

  7. sql server中创建链接服务器图解教程

    转自sql server中创建链接服务器图解教程 1.展开服务器对象-->链接服务器-->右击"新建链接服务器" 注意:必须以数据库管理员身份登录(通常也就是sa帐号) ...

  8. SQL SERVER表不能修改表结构的处理方法

    SQL SERVER表提示不能修改表结构,这究竟是什么原因呢?下面就为您介绍处理该问题的方法,如果您在SQL SERVER表修改方面遇到过问题,不妨一看. 新装的SQL SERVER 2008,打开原 ...

  9. SQL Server表分区详解

    原文:SQL Server表分区详解 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个文件里. 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆 ...

随机推荐

  1. hdu2534-Score

    http://acm.hdu.edu.cn/showproblem.php?pid=2534 由题知, 每一个数据都可以由ax +by组成: ax1 + by1 - c x2 a - d y2 == ...

  2. a5站长论坛和s8站长论坛-网上兼职做任务赚钱的两大网站

     1.什么是做任务赚钱? 简而言之,就是你做别人不在行而你在行的技术 ,如 图片美化 网站建设 网站修改 网站推广等网络业务. 2.任务赚钱有什么特点? 完全免费,你付出的是技术和时间,完全免费,不过 ...

  3. CPU内存管理和linux内存分页机制

    一.概念 物理地址(physical address)用于内存芯片级的单元寻址,与处理器和CPU连接的地址总线相对应.——这个概念应该是这几个概念中最好理解的一个,但是值得一提的是,虽然可以直接把物理 ...

  4. iOS开发-内存管理

    内存管理 对于这篇呢,其实现在都是ARC模式,正常状态下基本不用我们去手动释放内存,所以如果不是要面试呀.装逼或者扎实功底的,就先别看了或者了解下即可,因为像面试时,有些面试官想看你的基础时,就有些人 ...

  5. 【CSS学习笔记】整齐的表格

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...

  6. 为什么用Object.prototype.toString.call(obj)检测对象类型?

    最近做了做一些js面试25 Essential JavaScript Interview Questions*,其中第一道是:使用typeof bar === "object"检测 ...

  7. 怎样通过WireShark抓到的包分析出SIP流程图

    WireShark抓到了SIP包, 逐条分析, 看瞎...希望能够写个脚本, 自动生成流程图

  8. vue.js之个人总结

    1.MVVM模式 MVVM模式(Model-View-ViewModel)的运作如下图: 1)上图解析:ViewModel是Vue.js的核心,它是一个Vue实例.Vue实例是作用于某一个HTML元素 ...

  9. picturefill + picture 标签 实现兼容性很棒的 响应式图片 自适应 屏幕大小

    polyfill 它是一个能够补齐浏览器兼容性问题的一个东西,使用到的<picture></picture>标签 ,并不是所有浏览器都支持,为了实现更好的兼容效果,这里就使用到 ...

  10. 【转】Hive执行计划

    执行语句 hive> explain select s.id, s.name from student s left outer join student_tmp st on s.name = ...