标签:rtu type 操作 rac virtual protected mon framework clu
[Table("表名")]//设置表名 public class User { [Key] //设置主键 [Column("列名")] //设置列名 [DatabaseGenerated(DatabaseGeneratedOption.None)] //None 不自增 //Identity 自增 //Computed 数据库计算生成 public int Id{get;set;} [StringLength(10)] //varchar长度 public int Name{get;set;} [Required] //必要的(非空) [Column(TypeName="varchar")] //类型设置 public int LoginName{get;set;} public int Password{get;set;} [foreignKey("stu")] //设置外键 public int sid{get;set;} public student stu{get;set;} Nullable<int> age{get;set;} //让int 类型可以赋空值 //缩写为 int? age [NotMapped] //不在数据库生成 public string SumMoney{get;set;} }
EF生成数据库设置
public SQLContext():base("conStr") { Database.SetInitializer(new DropCreateDatabaseAlways<SQLContext>());//生成数据库设置 Database.SetInitializer<SQLContext>(null); //DropCreateDatabaseAlways<SQLContext> 执行一次删除重建一次数据库 //DropCreateDatabaseIfModelChanges<SQLContext> 当数据库模型发生变化时才删除重建数据库 //null 不会自动删除重建数据库 }
context.Database.Log = (msg) =>
{
Console.WriteLine(msg);
}
联表
EF做联表操作时,使用Include
foreach(var item in context.stu.Include("表名")) { } //或者 foreach(var item in context.stu.Include(m=>m.User)) //lambda { } //只拿出指定的列 foreach(var item in context.stu.Include(m=>m.User).Select(m=>new {m.title,m.user,...})) { }
EF中在属性中加上virtual,它就会变成懒加载,在使用时才会加载
直接用sql语句操作数据库,即使在上下文中没有的表也可以操作
context.Database.ExecuteSqlCommand("sql语句");
直接用sql语句操作数据库,并把结果封装到一个模型类中
context.Database.SqlQuery<封装的类>("sql语句");
EF不是所有lambda写法都能被支持,出错的时候,把那条语句单独提取出来用变量接收一下就行了
Context.Entry(对象).State = EntityState.xxxx;//强制修改对象状态
保存时不进行验证
Context.Configuration.ValidateOnSaveEnabled = false;
加上AsNoTracking() 可以让查询出来的对象直接变成游离态
Context.stu.AsNoTracking().Where(XXX);
关闭级联删除检测
protected override void OnModelCreating(DbModelBuilder modelBuider) { modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>(); modelBuilder.Conventions.Remove<ManyToManyCascadeDeleteConvention>(); }
当不确定是什么对象时使用set (例如使用泛型时)
Context.set<T> //set中给什么对象,他就会相当于什么对象使用
标签:rtu type 操作 rac virtual protected mon framework clu
原文地址:https://www.cnblogs.com/nicopoiduang/p/8886291.html