Sql Server 表创建以及Ef浅谈
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浅谈的更多相关文章
- 05Microsoft SQL Server 表创建,查看,修改及删除
Microsoft SQL Server 表创建,查看,修改及删除 创建表 创建普通表 use 数据库名称 go create table 表名称( 列1 ) not null, 列2 ) not n ...
- SQL server 表中如何创建索引?
SQL server 表中如何创建索引?看个示例,你就会了 use master goif db_id(N'zhangxu')is not nulldrop database zhangxugocre ...
- SQL Server表分区的NULL值问题
SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,但是本人觉得已经够用了 虽然MySQL支持四种分区类型:RANGE分区.LIST分区.HASH分区 ...
- SQL Server 表变量和临时表的区别
SQL Server 表变量和临时表的区别 一.表变量 表变量在SQL Server 2000中首次被引入.表变量的具体定义包括列定义,列名,数据类型和约束.而在表变量中可以使用的约束包括主键约束,唯 ...
- [转载]在SQL Server 中,如何实现DBF文件和SQL Server表之间的导入或者导出?
原来使用SQL Server 2000数据库,通过DTS工具很方便地在SQL Server和DBF文件之间进行数据的导入和导出,现在安装了SQL Server2005之后,发现其提供的“SQL Ser ...
- SQL Server表分区【转】
转自:http://www.cnblogs.com/knowledgesea/p/3696912.html SQL Server表分区 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在 ...
- sql server中创建链接服务器图解教程
转自sql server中创建链接服务器图解教程 1.展开服务器对象-->链接服务器-->右击"新建链接服务器" 注意:必须以数据库管理员身份登录(通常也就是sa帐号) ...
- SQL SERVER表不能修改表结构的处理方法
SQL SERVER表提示不能修改表结构,这究竟是什么原因呢?下面就为您介绍处理该问题的方法,如果您在SQL SERVER表修改方面遇到过问题,不妨一看. 新装的SQL SERVER 2008,打开原 ...
- SQL Server表分区详解
原文:SQL Server表分区详解 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个文件里. 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆 ...
随机推荐
- Linux kernel中网络设备的管理
kernel中使用net_device结构来描述网络设备,这个结构是网络驱动及接口层中最重要的结构.该结构不仅描述了接口方面的信息,还包括硬件信息,致使该结构很大很复杂.通过这个结构,内核在底层的网络 ...
- 【OpenMesh】创建一个正方体
原文出处: http://openmesh.org/Documentation/OpenMesh-Doc-Latest/tutorial.html 这个例程演示了: 如何声明MyMesh 如何添加顶点 ...
- Js 获取当前月的天数
function getDays() { //构造当前日期对象 var date = new Date(); //获取年份 var year = date.getFullYear(); //获取当前月 ...
- C语言之总结1
1). 终端常用的命令: pwd 显示终端的工作路径. ls list 清单 显示当前工作路径下的所有的文件以及文件夹. ls -l 以详细信息显示当前工作路径下的所有的文件以及文件夹. cd 要切 ...
- Mybatis原理图
Mybatis原理图 MyBatis 是一个基于Java的持久层框架.它提供的持久层框架包括SQL Maps和Data Access Objects(DAO). MyBatis 是支持普通 SQL查询 ...
- Swift Array copy 的线程安全问题
Swift Array copy 的线程安全问题 NSArray 继承自 NSObject,属于对象,有 copy 方法.Swift 的 Array 是 struct,没有 copy 方法.把一个 A ...
- java 线程池简介
线程池简介 通过前面的章节我们了解到如何去创建线程,但是如果我们每一次多去创建线程.我们是否回去想,既然是创建线程我们为什么不能像连接池一样呢.做到线程之间的复用呢,减少资源之间的让费呢? jdk为我 ...
- JavaSE——UDP协议网络编程(一)
UDP协议基础: UDP协议是英文UserDatagramProtocol的缩写,即用户数据报协议,主要用来支持那些需要在计算机之间传输数据的网络应用.包括网络视频会议系统在内的众多的客户/服务器模式 ...
- HTML5的文档结构
HTML5的文档结构 HTML5简化了许多,它的设计遵循了3个原则:1.兼容性.2.实用性.3.通用访问性 1. header 元素 <header> 标签定义文档或者文档 ...
- 《CLR Via C#》读书笔记,持续更新...
写了快5年代码了,一直都是使用别人发明的语言,别人发明的框架做快速开发,还从来没有真正深刻的学习过底层的一些东西,于是今年我打算读<CLR Via C#>这本书,认识一下C#的底层,我觉得 ...