- 增加 延时属性编译错误信息;
- 优化 FreeSql.Repository Autofac 泛型注入;
This commit is contained in:
2881099
2019-03-10 21:23:06 +08:00
parent 428220e754
commit ec2fcfb419
11 changed files with 277 additions and 87 deletions

View File

@ -1,5 +1,6 @@
using Autofac;
using Autofac.Extensions.DependencyInjection;
using FreeSql.DataAnnotations;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
@ -11,6 +12,77 @@ using System;
using System.Text;
namespace repository_01 {
public interface IBaseModel<TKey> {
TKey Id { get; set; }
}
/// <summary>
/// 用户密码信息
/// </summary>
public class SysUserLogOn : IBaseModel<Guid> {
[Column(IsPrimary = true)]
public Guid Id { get; set; } = Guid.NewGuid();
public Guid SysUserId { get; set; }
public string UserPassword { get; set; }
[Column(DbType = "varchar(100)")]
public string UserSecretkey { get; set; }
public DateTime PreviousVisitTime { get; set; } = DateTime.Now;
public DateTime LastVisitTime { get; set; } = DateTime.Now;
public int LogOnCount { get; set; }
public virtual SysUser SysUser { get; set; }
}
public class SysUser : IBaseModel<Guid> {
[Column(IsPrimary = true)]
public Guid Id { get; set; } = Guid.NewGuid();
[Column(DbType = "varchar(50)")]
public string AccountName { get; set; }
[Column(DbType = "varchar(50)")]
public string Name { get; set; }
public string HeadIcon { get; set; }
public Gender Gender { get; set; } = Gender.Man;
public DateTime Birthday { get; set; } = DateTime.MinValue;
[Column(DbType = "varchar(100)")]
public string MobilePhone { get; set; }
public string Email { get; set; }
public string WeChat { get; set; }
public string Description { get; set; }
public DateTime CreationTime { get; set; } = DateTime.Now;
public Guid? CreateUserId { get; set; }
public DateTime LastModifyTime { get; set; } = DateTime.Now;
public Guid? LastModifyUserId { get; set; }
public AccountState State { get; set; } = AccountState.Normal;
}
public enum Gender {
Man = 1,
Woman = 2,
}
public enum AccountState {
/// <summary>
/// 正常
/// </summary>
Normal = 1,
/// <summary>
/// 被禁用
/// </summary>
Disabled = 2,
/// <summary>
/// 已注销
/// </summary>
Closed = 3
}
public class Startup {
public Startup(IConfiguration configuration, ILoggerFactory loggerFactory) {
Configuration = configuration;
@ -19,7 +91,14 @@ namespace repository_01 {
.UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=|DataDirectory|\document.db;Pooling=true;Max Pool Size=10")
.UseLogger(loggerFactory.CreateLogger<IFreeSql>())
.UseAutoSyncStructure(true)
.UseLazyLoading(true)
.Build();
var sysu = new SysUser { };
Fsql.Insert<SysUser>().AppendData(sysu).ExecuteAffrows();
Fsql.Insert<SysUserLogOn>().AppendData(new SysUserLogOn { SysUserId = sysu.Id }).ExecuteAffrows();
var a = Fsql.Select<SysUserLogOn>().ToList();
var b = Fsql.Select<SysUserLogOn>().Any();
}
public IConfiguration Configuration { get; }
@ -41,8 +120,8 @@ namespace repository_01 {
var builder = new ContainerBuilder();
builder.RegisterFreeRepository<Song>(a => a.Id == 1);
builder.RegisterFreeGuidRepository<Song>(a => a.Id == 1, oldname => $"{oldname}_{DateTime.Now.Year}");
builder.RegisterFreeRepositoryAddFilter<Song>(() => a => a.Title == DateTime.Now.ToString() + System.Threading.Thread.CurrentThread.ManagedThreadId);
//builder.RegisterFreeGuidRepository<Song>(a => a.Id == 1, oldname => $"{oldname}_{DateTime.Now.Year}");
builder.Populate(services);
var container = builder.Build();

View File

@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>netcoreapp2.2</TargetFramework>
<TargetFramework>netcoreapp2.1</TargetFramework>
<AspNetCoreHostingModel>InProcess</AspNetCoreHostingModel>
</PropertyGroup>