> 文档中心 > .Net Framework 471下的SQLSugar+PostgreSQL 13的笔记

.Net Framework 471下的SQLSugar+PostgreSQL 13的笔记


.Net Framework 471下的SQLSugar+PostgreSQL 13记录笔记

一、环境说明(楼主只试过以下版本的,早前试别的版本会出现Exception_WasThrow的情况,知道什么原因的可以在文章下评论):

.Net框架:.Net Framework 471

ORM框架:SQLSugar 5.0.3.5

PG包:Npgsql 4.0.10.0

数据库版本:PostgreSQL Enterprise 13

二、上面环境准备好之后,新建EF仓储实例类并继承SQLSugar的SimpleClient,如图。

public class Repository<T> : SimpleClient<T> where T : class, new()    { public Repository(ISqlSugarClient context = null) : base(context)//注意这里要有默认值等于null {     if (context == null)     {  base.Context = new SqlSugarClient(new ConnectionConfig()  {      DbType = SqlSugar.DbType.PostgreSQL,      InitKeyType = InitKeyType.Attribute,      IsAutoCloseConnection = true,      MoreSettings = new ConnMoreSettings()      {   PgSqlIsAutoToLower = false //数据库存在大写字段的 ,需要把这个设为false ,并且实体和字段名称要一样      },      ConnectionString = "PORT=5630;DATABASE=tshoteldb;HOST=localhost;PASSWORD=postgres;USER ID=postgres"  });  base.Context.Aop.OnLogExecuting = (s, p) =>  {      Console.WriteLine(s);  };     } }

三、建立对应的实体类,这里我们建一个名为AdminInfo的实体类。

注意:[SqlSugar.SugarTable(“表名”)]建议都强制加上,以及数据库字段的[SqlSugar.SugarColumn(ColumnName = “字段名”)]也强制加上,否则容易报“关系‘xxxx’不存在…”等类似的错。

[SqlSugar.SugarTable("admininfo")] public class AdminInfo {     [SqlSugar.SugarColumn(ColumnName = "AdminAccount")]     public string AdminAccount { get; set; }     [SqlSugar.SugarColumn(ColumnName = "AdminPassword")]     public string AdminPassword { get; set; }     [SqlSugar.SugarColumn(ColumnName = "AdminType")]     public string AdminType { get; set; }     [SqlSugar.SugarColumn(ColumnName = "AdminName")]     public string AdminName { get; set; }     [SqlSugar.SugarColumn(ColumnName = "IsAdmin")]     public int IsAdmin { get; set; }     [SqlSugar.SugarColumn(ColumnName = "DeleteMk")]     public int DeleteMk { get; set; } }

四、接下来就可以开始写业务逻辑了,我们这里建一个名为AdminService并且继承Repository,里对应的是要操作的实体类名称。

public class AdminService : Repository<AdminInfo> {     public List<AdminInfo> GetLists()     {  var list = base.GetList(a => a.DeleteMk != 1);  return list;     } }

五、最后进行调用。

static void Main(string[] args) {     Console.WriteLine(string.Join("\n", new AdminService().GetLists().Select(a => a.AdminAccount)));     Console.ReadKey(); }

六、运行结果:

在这里插入图片描述

七、总结:

​ 其实SQLSugar已经做了大部分与数据库打交道的工作了,我们只是稍微改下配置即可,但是SQLSugar版本要与Npgsql版本要兼容匹配,否则会出现各种各样的报错,之前就因为这样烦恼了楼主两天时间,唉,归咎只是自己太菜。最后,如果大家知道其他SQLSugar版本和Npgsql版本可以兼容的话可以写在文章下方,汇总成一个表格方便大家更愉快地使用SQLSugar+PostgreSQL吧!
成一个表格方便大家更愉快地使用SQLSugar+PostgreSQL吧!

字体下载