.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吧!