背景:网上很多CodeFirst通过实体创建数据库表的例子,现实开发过程中有DbFirst的需求,这里做一个简单记录,供以后开发使用。
CodeFirst的文章也转发一个,有备无患:基于.NET6平台开发WebApi(七)—— 添加Sqlsugar支持
还有就是SqlSugar这个ORM框架的文档链接留一个:SqlSugar ORM 5.X 官网 、文档、教程
所有代码是在另外创建的控制台项目的Program.cs文件中写的。
1、首先安装nuget包:RazorEngine.NetCore
直接上代码:
using NET6.Domain.Entities; using RazorEngine; using RazorEngine.Templating; using SqlSugar; var db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = "【数据库连接语句】", DbType = DbType.MySql, IsAutoCloseConnection = true, InitKeyType = InitKeyType.Attribute, ConfigureExternalServices = new ConfigureExternalServices() { RazorService = new RazorService() } }); db.DbFirst.UseRazorAnalysis(RazorFirst.DefaultRazorClassTemplate).CreateClassFile("D:\\【实体们存放的项目路径】"); #region 对话框 Console.WriteLine("是否确定生成实体?(回车确认)"); var str = Console.ReadKey(); if (str.Key == ConsoleKey.Enter) { Console.WriteLine("同步中,请稍后..."); } else { Console.WriteLine("\r\n输入错误,已退出..."); return; } #endregion public class RazorService : IRazorService { public List<KeyValuePair<string, string>> GetClassStringList(string razorTemplate, List<RazorTableInfo> model) { if (model != null && model.Any()) { var result = new List<KeyValuePair<string, string>>(); foreach (var item in model) { try { item.ClassName = item.DbTableName;//格式化类名 string key = "RazorService.GetClassStringList" + razorTemplate.Length; var classString = Engine.Razor.RunCompile(razorTemplate, key, item.GetType(), item); result.Add(new KeyValuePair<string, string>(item.ClassName, classString)); } catch (Exception ex) { new Exception(item.DbTableName + " error ." + ex.Message); } } return result; } else { return new List<KeyValuePair<string, string>>(); } } }
运行完代码之后,实体就出现了,成功;