EntityFramework Core笔记:表结构及数据基本操作(2)
1. 表结构操作
1.1 表名
Data Annotations:
using System.ComponentModel.DataAnnotations.Schema;
[Table("Role")]
public class Role
{
// ...
}
FluentAPI:
using Microsoft.EntityFrameworkCore;
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Role>().ToTable("Role");
}
1.2 字段
Data Annotations:
using System;
using System.Collections.Generic;
using System.Text; using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema; namespace Libing.App.Models.Entities
{
[Table("Role")]
public class Role
{
[Column("RoleID")]
public int RoleID { get; set; } [Required]
[Column("RoleName",TypeName = "varchar(200)")]
public string RoleName { get; set; }
}
}
FluentAPI:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Role>().ToTable("Role");
modelBuilder.Entity<Role>()
.Property(t => t.RoleID)
.HasColumnName("RoleID");
modelBuilder.Entity<Role>()
.Property(t => t.RoleName)
.HasColumnName("RoleName")
.HasColumnType("varchar(200)")
//.HasMaxLength(200)
.IsRequired();
}
1.3 主键
Data Annotations:
[Table("Role")]
public class Role
{
[Key]
public int RoleID { get; set; }
}
FluentAPI:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Role>()
.HasKey(t => t.RoleID); // 复合主键
//modelBuilder.Entity<Role>()
// .HasKey(t => new { t.RoleID, t.RoleName });
}
1.4 计算列
FluentAPI:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<User>()
.Property(t => t.DisplayName)
.HasComputedColumnSql("[LastName] + ',' + [FirstName]");
}
CREATE TABLE [Users] (
[UserID] int NOT NULL IDENTITY,
[DisplayName] AS [LastName] + ',' + [FirstName],
[FirstName] nvarchar(max) NULL,
[LastName] nvarchar(max) NULL,
CONSTRAINT [PK_Users] PRIMARY KEY ([UserID])
);
1.5 生成值
主键属性如果是整数或Guid类型,该属性将会被EntityFramework Core设置为自动生成。
Data Annotations:
(1)没有生成值
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int RoleID { get; set; }
(2)添加操作生成值
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int RoleID { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public DateTime ModifiedDate { get; set; }
(3)添加或修改操作生成值
[DatabaseGenerated(DatabaseGeneratedOption.Computed)]
public DateTime ModifiedDate { get; set; }
FluentAPI:
modelBuilder.Entity<Role>()
.Property(t => t.RoleID)
.ValueGeneratedOnAdd();
modelBuilder.Entity<Role>()
.Property(t => t.ModifiedDate)
.ValueGeneratedNever();
modelBuilder.Entity<Role>()
.Property(t => t.ModifiedDate)
.ValueGeneratedOnAdd();
modelBuilder.Entity<Role>()
.Property(t => t.ModifiedDate)
.ValueGeneratedOnAddOrUpdate();
注:按照约定,非复合主键的类型 short、 int、 long、 或 Guid 将安装程序能够生成上添加的值。
所有其他属性将与不值生成的安装程序。
1.6 默认值
modelBuilder.Entity<Role>()
.Property(t => t.RoleName)
.HasDefaultValue(String.Empty);
modelBuilder.Entity<Role>()
.Property(t => t.ModifiedDate)
.HasDefaultValueSql("GETDATE()");
CREATE TABLE [Role] (
[RoleID] int NOT NULL IDENTITY,
[ModifiedDate] datetime2 NOT NULL DEFAULT (GETDATE()),
[RoleName] varchar(200) NOT NULL DEFAULT N'',
CONSTRAINT [PK_Role] PRIMARY KEY ([RoleID])
);
1.7 序列
modelBuilder.HasSequence<int>("RoleSequence", "dbo")
.StartsAt()
.IncrementsBy();
modelBuilder.Entity<Role>()
.Property(t => t.RoleID)
.HasDefaultValueSql("NEXT VALUE FOR dbo.RoleSequence");
CREATE SEQUENCE [dbo].[RoleSequence] AS int START WITH 1 INCREMENT BY 1 NO MINVALUE NO MAXVALUE NO CYCLE;
CREATE TABLE [dbo].[Role] (
[RoleID] int NOT NULL DEFAULT (NEXT VALUE FOR dbo.RoleSequence),
[ModifiedDate] datetime2 NOT NULL,
[RoleName] varchar(200) NOT NULL,
CONSTRAINT [PK_Role] PRIMARY KEY ([RoleID])
);
1.8 索引
modelBuilder.Entity<Role>()
.HasIndex(t => t.RoleName)
.HasName("IX_RoleName");
CREATE INDEX [IX_RoleName] ON [dbo].[Role] ([RoleName]);
modelBuilder.Entity<Role>()
.HasIndex(t => t.RoleName)
.IsUnique()
.HasName("IX_RoleName");
CREATE UNIQUE INDEX [IX_RoleName] ON [dbo].[Role] ([RoleName]);
1.9 默认架构
modelBuilder.HasDefaultSchema("dbo");
1.10 完整实体类配置
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Role>(entity =>
{
// Primary Key
entity.HasKey(t => t.RoleID); // Properties
entity.Property(t => t.RoleName).HasMaxLength(); // Table & Column Mappings
entity.ToTable("Role", "dbo");
entity.Property(t => t.RoleID).HasColumnName("RoleID");
entity.Property(t => t.RoleName).HasColumnName("RoleName");
});
}
RoleConfiguration.cs
using System;
using System.Collections.Generic;
using System.Text; using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders; using Libing.App.Models.Entities; namespace Libing.App.Models.Configurations
{
public class RoleConfiguration : IEntityTypeConfiguration<Role>
{
public void Configure(EntityTypeBuilder<Role> builder)
{
// Primary Key
builder.HasKey(t => t.RoleID); // Properties
builder.Property(t => t.RoleName)
.IsRequired()
.HasMaxLength(); // Table & Column Mappings
builder.ToTable("Role", "dbo");
builder.Property(t => t.RoleID).HasColumnName("RoleID");
builder.Property(t => t.RoleName).HasColumnName("RoleName");
}
}
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.ApplyConfiguration(new RoleConfiguration());
}
2. 表数据操作
EntityFramework Core笔记:表结构及数据基本操作(2)的更多相关文章
- sqlserver删除所有表(表结构和数据)
要删除某个数据库,或者删除数据库中的所有表(删除表结构和数据),需要先删除表间的外键约束,才能删除表.如删除数据库db_wy中的所有表: --/第1步**********删除所有表的外键约束***** ...
- SQL Server表结构和数据导入到MySQL
借助的工具:Navicat for MySQL,链接:http://pan.baidu.com/s/1kVCw8IF 密码:g927 可以很明确的肯定,主键和自增列是没办法导入的,只能是表结构和数据. ...
- Oracle备份表结构和数据
--创建一份表结构 create table BASE_GOODSPAYMENT_SETTING_BAK as select * from BASE_GOODSPAYMENT_SETTING ; -- ...
- MySQL 如何只导出 指定的表 的表结构和数据 ( 转 )
MySQL 如何只导出 指定的表 的表结构和数据 ( 转 ) 2011-01-04 15:03:33 分类: MySQL MySQL 如何只导出 指定的表 的表结构和数据 导出更个库的表结构如下:my ...
- 复制表结构和数据SQL语句
select * into 目标表名 from 源表名 insert into 目标表名(fld1, fld2) select fld1, 5 from 源表名 以上两句都是将 源表 的数据插入到 目 ...
- SQL复制表结构和数据
1.复制表结构和数据 select * into 目的数据库名.dbo.目的表名 from 原表名 select * into my0735home.dbo.infoMianTest from inf ...
- SQL——表结构或数据的复制
一.复制表结构及数据到新表 create table new_tb select * from old_tb 二.只复制表结构到新表 create table new_tb select * from ...
- orcale复制表结构及其数据
http://hi.baidu.com/tag/Oracle/feeds http://hi.baidu.com/gqftuisidibabiq/item/14d306cc87cbdf45bcef69 ...
- Oracle复制表结构及数据
1. 复制表结构及其数据: create table table_name_new as select * from table_name_old 2. 只复制表结构: ; 或者: create ...
随机推荐
- 【学习笔记】tensorflow图片读取
目录 图像基本概念 图像基本操作 图像基本操作API 图像读取API 狗图片读取 CIFAR-10二进制数据读取 TFRecords TFRecords存储 TFRecords读取方法 图像基本概念 ...
- 开源介绍·新款简约、实用与大气的Hexo新主题:BMW
这是一个简约.大气.实用的Hexo新主题:BMW
- 关于HTTP中GET与POST的区别
GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一二. 看似很简单,其实是一道送命题 “标准答案”: GET在浏览器回退时是无害的,而POST会再次提交请求. ...
- vue init初始化项目后 npm run dev报错 10% building modules 1/1 modules 0 activeevents.js:182 throw er; // Unhandled 'error' event
报错信息: 10% building modules 1/1 modules 0 activeevents.js:182 throw er; // Unhandled 'error' ev ...
- python运行逻辑
Python程序在解释器上执行分两个过程: 编译:如果Python进程在机器上拥有写入权限,那么它会把程序的字节码保存为一个以 .pyc 为扩展名的文件.当程序运行后,会在源代码的同一个目录下看到 . ...
- LEDAPS1.3.0版本移植到windows平台----HuSr大气校正模块
这个是2012年左右放在百度空间的,谁知百度空间关闭...转移到博客园. 最近项目用到3.1.2版本的LEDAPS,新版本的使用情况会在后续文章中慢慢丰富. HuSr是将LEDAPS项目中的TM/ET ...
- 利用自定义View实现扫雷游戏
游戏规则: 简单版的扫雷事实上就是一个9×9的矩阵,其中有十个点是雷,非雷方块的数字代表该方块周围八个方块中雷的个数.通过长按某一方块(方块会变红)认定该方块为玩家认为的雷,通过短按某一方块来“展开” ...
- PM过程管理成熟度1级
之前,我已经从项目实现的角度.企业管理诉求两方面,分析了PM的核心能力架构,以及其在过程管理方面的能力等级.接下来,Fancier凡奉信息会站在PM能力成长的角度,横向与纵向阐述每一成熟度等级PM的过 ...
- 小小白搭建nextcloud云盘
我是一名linux的小小白,今天就利用自己的所学搭建属于自己的云盘——nextcloud. 本人学生狗,普通的云盘也要几十块钱,既然我们只是拿来搭建巩固自己知识并不做为生产力,我们就用VMware W ...
- layui中弹出层的两种表达方式
方式一: 定义js中定义html变量 方式二: 设置div :hidden:hidden 布局 数据表格自适应大小: 代码: <style> .btn-container { margin ...