.net6开发webapi——SqlSugar的DbFirst创建实体
2022/7/6 2:20:14
本文主要是介绍.net6开发webapi——SqlSugar的DbFirst创建实体,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
背景:网上很多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>>(); } } }
运行完代码之后,实体就出现了,成功;
这篇关于.net6开发webapi——SqlSugar的DbFirst创建实体的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-12-06使用Microsoft.Extensions.AI在.NET中生成嵌入向量
- 2024-11-18微软研究:RAG系统的四个层次提升理解与回答能力
- 2024-11-15C#中怎么从PEM格式的证书中提取公钥?-icode9专业技术文章分享
- 2024-11-14云架构设计——如何用diagrams.net绘制专业的AWS架构图?
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#