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 ...
随机推荐
- Java学习笔记——i++与++i问题
不同情况分析 逻辑运算符,++/--在前则先执行++/--.在后面则后执行++/-- k++是执行逻辑判断符号,之后再进行k的递增 int k=3; k++==3; //结果为true ++k则是先递 ...
- Java基础:Object类中的equals与hashCode方法
前言 这个系列的文章主要用来记录我在学习和复习Java基础知识的过程中遇到的一些有趣好玩的知识点,希望大家也喜欢. 一切皆对象 对于软件工程来说面向对象编程有一套完整的解决方案:OOA.OOD.O ...
- excel 函数1
1 函数的相对引用和绝对引用 1.1绝对引用,相对引用和混合引用 按住F4键可以相互切换 1.2 if and or函数 案例图片 =IF(C7>30000,"大商家",&q ...
- vue 获取页面详情后 切换页面时 如何监听用户是否修改过信息
可以用 beforeRouteLeave 和 updated 来判断.export default { name: 'supplier', components:{cmtWrap,cmtContent ...
- input中只能写入数字int、float
input 属性 type="number" <input type="number" min="1" max="100&q ...
- Android为TV端助力 完全解析模拟遥控器按键
public class VirturlKeyPadCtr { private static Instrumentation mInstrumentation; public static void ...
- 基础环境系列:PHP7.3.0并连接pache/IIS和MySQL
版本: php7.3.0 MySQL8.0.12 Apache2.4 IIS8 一.下载PHP 1.下载php3.7 PHP版本:php7.3(7.3.0) 下载地址:https://windows ...
- REST风格架构
一说到rest 大家都耳熟能详,很多人的第一反应就是其是前后端请求后台的一种通信方式,甚至有些人将REST 和RPC 混为一谈,认为两者都是基于HTTP类似的东西.实际上很少人能叙述REST 所提出的 ...
- 利用ZYNQ SOC快速打开算法验证通路(5)——system generator算法IP导入IP integrator
一.前言 利用FPGA设计算法一直以来都是热点,同样也是难点.将复杂的数学公式 模型通过硬件系统来搭建,在低延时 高并行性等优势背后极大提高了设计难度和开发周期.Xilinx公司的sysGen(sys ...
- Go语言学习笔记-函数部分(三)
函数部分 函数基本组成:关键字func.函数名.参数列表.返回值.函数体.返回语句 例子: func Add(int a, int b) (return int, err error){ ....函数 ...