AbpUser 扩展
AbpUser表存放的信息比较少,现扩展一下信息
1、在Core层添加UserExtend 类,继承 AbpUser<User>,写入以上各项属性字段,并添加Discriminator 字段,Discriminator用于指明数据所在实体的名称,最终代码如下:(不需要扩展ID和用户ID,发布了折叠的代码无法编辑┭┮﹏┭┮)
public class UserExtend: AbpUser<User>
{
#region Public Property
///<Summary>
/// Id 用户信息ID
///</Summary>
[Display(Name = "用户信息ID")]
public long Id { get; set; }
///<Summary>
/// UserId 用户ID
///</Summary>
[Display(Name = "用户ID")]
public long UserId { get; set; }
///<Summary>
/// GroupID 分组:机构型,客户型
///</Summary>
[Display(Name = "分组:机构型,客户型")]
public int GroupID { get; set; }
///<Summary>
/// Avatar 头像
///</Summary>
[Display(Name = "头像")]
public string Avatar { get; set; }
///<Summary>
/// Sex 性别
///</Summary>
[Display(Name = "性别")]
public int Sex { get; set; }
///<Summary>
/// Birthday 生日
///</Summary>
[Display(Name = "生日")]
public DateTime Birthday { get; set; }
///<Summary>
/// Province 省
///</Summary>
[Display(Name = "省")]
public string Province { get; set; }
///<Summary>
/// City 市
///</Summary>
[Display(Name = "市")]
public string City { get; set; }
///<Summary>
/// County 县
///</Summary>
[Display(Name = "县")]
public string County { get; set; }
///<Summary>
/// Address 联系地址
///</Summary>
[Display(Name = "联系地址")]
public string Address { get; set; }
///<Summary>
/// QQ QQ
///</Summary>
[Display(Name = "QQ")]
public string QQ { get; set; }
///<Summary>
/// WeChat 微信
///</Summary>
[Display(Name = "微信")]
public string WeChat { get; set; }
///<Summary>
/// DingTalk 钉钉
///</Summary>
[Display(Name = "钉钉")]
public string DingTalk { get; set; }
///<Summary>
/// Skype Skype
///</Summary>
[Display(Name = "Skype")]
public string Skype { get; set; }
///<Summary>
/// WhatsApp WhatsApp
///</Summary>
[Display(Name = "WhatsApp")]
public string WhatsApp { get; set; }
///<Summary>
/// Stack Stack
///</Summary>
[Display(Name = "Stack")]
public string Stack { get; set; }
#endregion /// <summary>
/// 自定义实体类名称
/// </summary>
[MaxLength()]
private string Discriminator { get { return "UserExtend"; } }
}
2、在EF层的EntityMapper文件夹中添加配置信息,将生成的表名指向 AbpUsers,最终代码如下:
/// <summary>
/// Description 户信息补充
/// </summary>
public class UserExtendCfg : IEntityTypeConfiguration<UserExtend>
{
public void Configure(EntityTypeBuilder<UserExtend> builder)
{
builder.ToTable("AbpUsers");
builder.Property(a => a.Avatar).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length255);
builder.Property(a => a.Address).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length255);
builder.Property(a => a.QQ).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50);
builder.Property(a => a.WeChat).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50);
builder.Property(a => a.DingTalk).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50);
builder.Property(a => a.Skype).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50);
builder.Property(a => a.WhatsApp).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50);
builder.Property(a => a.Stack).HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length50); builder.Property(a => a.Province).HasColumnType("char(20)").HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length20);
builder.Property(a => a.City).HasColumnType("char(20)").HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length20);
builder.Property(a => a.County).HasColumnType("char(20)").HasMaxLength(YoYoAbpefCoreConsts.EntityLengthNames.Length20);
}
}
注意char类型数据的写法,如果不这样写生成的依然是nvarchar,
YoYoAbpefCoreConsts.EntityLengthNames.Length20 是const的长度,具体定义如下:
/// <summary>
/// 实体长度单位
/// </summary>
public static class EntityLengthNames
{
public const int Length8 = ;
public const int Length10 = ;
public const int Length16 = ;
public const int Length20 = ;
public const int Length30 = ;
public const int Length32 = ;
public const int Length50 = ;
public const int Length64 = ;
public const int Length100 = ;
public const int Length128 = ;
public const int Length200 = ;
public const int Length255 = ;
public const int Length300 = ;
public const int Length500 = ;
public const int Length512 = ;
public const int Length1000 = ;
public const int Length4000 = ; public const int Length1024 = ; }
3、在EF层 DbContext中增加:
public DbSet<UserExtend> UserExtends { get; set; }
在EF层 DbContext类OnModelCreating方法中添加以下代码 替换原来的数据库生成配置 modelBuilder.ApplyConfiguration(new UserExtendCfg()); 4、然后就是执行数据库迁移了,然而,居然是错的。。。。。。。。。。。第一反应就是尼玛,组织机构都是这样扩展的啊,怎么到了用户就不行了呢XXXXXXXXXX
百度了半天,也没有相关的文章,没有一点头绪,只好一点点的比对代码,然后总觉得继承的那个 AbpUser<User>怪怪的,顺便把角色也翻出来看了一下,然后发现,角色下面有这样一段,豁然开朗:
原来 AbpUser<User> 就是对用户的扩展啊,好了以上可重新整理了 1、将需要扩展的字段搬到 User类下(不需要Discriminator)
2、修改UserExtendCfg 类,让它基于User而不是UserExtend(也就是将上面UserExtendCfg 中的UserExtend全部替换为User啦)
3删掉public DbSet<UserExtend> UserExtends { get; set; }
4、执行迁移
完成效果
这种方法在我后期遇到一个问题,我后面有一次数据库的表结构调整比较大,于是我删了所有的更新日志,然后重建自己更新的这些表,在执行数据库迁移的时候发现,User和Role添加的字段都没有更新到数据库,我反复修改猜想可能的原因,最终百度到这篇大神的文章https://www.cnblogs.com/wer-ltm/p/7097623.html
发现不同的地方是,我的字段不是virtual的,改为virtual就可以了,虽然我有一种错觉,在没有改为virtual之前,我已经看见迁移代码中出现了我要添加的字段,但是没有时间再试了,这个小小的错误,耽误了我半天的时间,先记在这里,后面有时间再试(2019年9月17日)
麻蛋,在我又一次删除所有迁移问题之后,这个问题又出现了!!!!!!!为什么我上次没有记下来几次试错以及恍惚解决时做哪些更改呢,真是太恶心了!!!!!!!!!!!!!!!!!!!!!!这次不知道又要多久啊!!!!!!!!!!!!!!!还有,各位大大没有发生过迁移时删除字段无效的问题吗????每次遇见这种问题,我都只有删了迁移文件重新生成┭┮﹏┭┮(2019-9-27 07:10:41)
AbpUser 扩展的更多相关文章
- 在ABPZERO中,扩展实体的方法。
内容 介绍 扩展的抽象实体 将新属性添加给用户 添加迁移 在界面上显示地址 在用户编辑/添加功能中添加地址 扩展的非抽象类实体 获得版本的派生实体 添加迁移 在界面上添加价格 在创建/编辑版本功能中加 ...
- abp加DDD开发:低耦合、可复用、可扩展的【工单】业务模块-简介和集成
前言 很多场景[单体+模块化]比微服务更合适,开发难度低.代码可复用性强.可扩展性强.模块化开发有些难点,模块启动与卸载.模块之间的依赖和通讯.asp.net core abp为我们提供了模块化开发能 ...
- Asp.net Boilerplate之AbpSession扩展
当前Abp版本1.2,项目类型为MVC5. 以属性的形式扩展AbpSession,并在"记住我"后,下次自动登录也能获取到扩展属性的值,版权归"角落的白板报"所 ...
- 恢复SQL Server被误删除的数据(再扩展)
恢复SQL Server被误删除的数据(再扩展) 大家对本人之前的文章<恢复SQL Server被误删除的数据> 反应非常热烈,但是文章里的存储过程不能实现对备份出来的日志备份里所删数据的 ...
- .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法
.NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...
- .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类
.NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...
- 采用EntityFramework.Extended 对EF进行扩展(Entity Framework 延伸系列2)
前言 Entity Framework 延伸系列目录 今天我们来讲讲EntityFramework.Extended 首先科普一下这个EntityFramework.Extended是什么,如下: 这 ...
- Dapper扩展之~~~Dapper.Contrib
平台之大势何人能挡? 带着你的Net飞奔吧!http://www.cnblogs.com/dunitian/p/4822808.html#skill 上一篇文章:Dapper逆天入门~强类型,动态类型 ...
- ExtJS 4.2 Date组件扩展:添加清除按钮
ExtJS中除了提供丰富的组件外,我们还可以扩展他的组件. 在这里,我们将在Date日期组件上添加一个[清除]按钮,用于此组件已选中值的清除. 目录 1. Date组件介绍 2. 主要代码说明 3. ...
随机推荐
- codeforces 816B Karen and Coffee (差分思想)
题目链接 816B Karen and Coffee 题目分析 题意:有个人在学泡咖啡,因此看了很多关于泡咖啡温度的书,得到了n种推荐的泡咖啡温度范围[L1,R1] ,此人将有k种做法推荐的温度记为可 ...
- [Codeforces 266E]More Queries to Array...(线段树+二项式定理)
[Codeforces 266E]More Queries to Array...(线段树+二项式定理) 题面 维护一个长度为\(n\)的序列\(a\),\(m\)个操作 区间赋值为\(x\) 查询\ ...
- selenium与页面交互
selenium提供了许多API方法与页面进行交互,如点击.键盘输入.打开关闭网页.输入文字等. 一.webdriver对浏览器提供了很多属性来对浏览器进行操作,常用的如图: get(url).qui ...
- MySQL性能优化(二):优化数据库的设计
原文:MySQL性能优化(二):优化数据库的设计 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.n ...
- 图片哈希概论及python中如何实现对比两张相似的图片
Google 以图搜图的原理,其中的获取图片 hash 值的方法就是 AHash. 每张图片都可以通过某种算法得到一个 hash 值,称为图片指纹,两张指纹相近的图片可以认为是相似图片. 以图搜图的原 ...
- 部署Dashboard,监控应用
部署web UI(dashboard)用于监控node资源 参见文档:https://blog.csdn.net/networken/article/details/85607593 官网:https ...
- mysql复习(2)
一.数据定义: SQL数据的定义包括模式的定义.表定义.视图定义和索引的定义. 1.基本的模式定义情况如下表. 2.一个关系数据库管理系统的实例中可以创建多个数据库,一个数据库中可以建立多个模式,一个 ...
- 第十六篇 JS实现全选操作
JS实现全选 嗨,同学们好,老师这里是专门教同学解决一些针对性的问题,所以说综合起来,就要靠同学自己了. 这节课我们学一个很实用的东西,全选操作!比如淘宝这种商城对吧,我的购物车,我要全选购买,或 ...
- 多线程编程-- part 6 共享锁和ReentrantReadWriteLock
介绍: ReadWriteLock,顾名思义,是读写锁.它维护了一对相关的锁 — — “读取锁”和“写入锁”,一个用于读取操作,另一个用于写入操作.(1)“读取锁”用于只读操作,它是“共享锁”,能同时 ...
- SQL SERVER 中 sp_rename 用法
转自:http://www.cnblogs.com/no7dw/archive/2010/03/04/1678287.html 因需求变更要改表的列名,平常都是跑到Enterprise manager ...