五、SQLSugar 配置实体(CodeFirstDBFirst)

2024-01-14 11:59

本文主要是介绍五、SQLSugar 配置实体(CodeFirstDBFirst),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

配置实体 - SqlSugar 5x - .NET果糖网https://www.donet5.com/Home/Doc?typeId=1182一、Nuget 引入 SqlSugarCore

二、新建实体

using SqlSugar;namespace Model.DBEntity
{/// <summary>/// 国家地区表/// </summary>[SugarTable("Country")]//当和数据库名称不一样可以设置表别名 指定表明public class Country{/// <summary>/// 自增主键ID,可给多个字段设置主键达到双主键、复合主键、联合主键、多个主键/// </summary>[SugarColumn(IsPrimaryKey =true, IsIdentity = true,ColumnDescription="主键")]//设置主键,设置自增,字段注释public int FID { get; set; }/// <summary>/// 上级ID/// </summary>[SugarColumn(ColumnName = "FPID", ColumnDescription = "上级主键")]//数据库列名与实体不一样,指定数据库字段名public int FPID { get; set; }/// <summary>/// 名称/// </summary>[SugarColumn(ColumnDescription = "名称")]public string? FName { get; set; }/// <summary>/// 递归自己/// </summary>[SugarColumn(IsIgnore =true, ColumnDescription = "下级集合")]//IsIgnore	ORM不处理该列 【忽略】public List<Country>? CountryList { get; set; }}
}

三、同步到数据库,控制台代码

using DBSyncTool;
using SqlSugar;
using System.Reflection;// See https://aka.ms/new-console-template for more information//数据库账号密码
string user = "sa";
string pwd = "***";
//
//string user = "yfl";
//string pwd = "ydl..yfl";//打印方法
var Begin = () => Console.WriteLine("┌──────────────────────────────────────────────────────────┐");
var Content = (string context) => Console.WriteLine(@$"│ {context} ");
var End = () => Console.WriteLine("└──────────────────────────────────────────────────────────┘");
var All = (string context) =>
{Begin();Content(context);End();
};
var ReStart = () =>
{for (int i = 0, m = 1; i < 30; i++)for (int l = 0; l < new[] { 5, 6, 7, 6, 8, 10, 3, 10, 4, 13, 1, 13, 1, 87, 1, 27, 4, 23, 7, 20, 11, 16, 16, 11, 20, 7, 24, 3, 27, 1 }[i]; l++, m++)Console.Write((i % 2 > 0 ? "love"[m % 4] : ' ') + (m % 29 > 0 ? "" : "\n"));Console.WriteLine();
};//数据库操作类型
string[] _syncarr = { "DBFirst", "CodeFirst", "AddDataBase", "Back" };//获取的到数据库列表
Fun f = new();
List<string> _dbarr = global::DBSyncTool.Fun.GetDBList(user, pwd);All("请谨慎做出你的选择,因为这是不可撤销的");
All("CodeFirst需自行代码调整需要同步的Table");
ChooseDB:
Begin();
Content("请选择数据库名称:");
int inx = 0;
foreach (string s in _dbarr)
{Content(@$"{++inx}:{s}");
}
End();int? dbstr = 0;
Wdb:
try
{dbstr = Convert.ToInt32(Console.ReadLine()) - 1;while (dbstr >= _dbarr.Count || dbstr < 0){All("请输入有效的数据库编号! ");dbstr = Convert.ToInt32(Console.ReadLine()) - 1;}
}
catch (Exception)
{All("请输入有效的数据库编号! ");goto Wdb;
}Begin();
Content(@$"【{_dbarr[(int)dbstr]}】");
Content("请选择数据库结构同步方式:");
inx = 0;
foreach (string s in _syncarr)
{Content(@$"{++inx}:{s}");
}
End();int? type = 0;
Wsync:
try
{type = Convert.ToInt32(Console.ReadLine()) - 1;while (type >= _syncarr.Length || type < 0){Content(@$"【{_dbarr[(int)dbstr]}】");All("请输入有效的同步方式编号!");type = Convert.ToInt32(Console.ReadLine()) - 1;}
}
catch (Exception)
{Content(@$"【{_dbarr[(int)dbstr]}】");All("请输入有效的同步方式编号!");goto Wsync;
}string? sure = "";
if (_syncarr[(int)type] == "Back")
{ReStart();goto ChooseDB;
}
else
{Begin();Content($@"请确认您选择的数据库同步方式:【{_dbarr[(int)dbstr]}】【{_syncarr[(int)type]}】");Content("1 : 确认!开始同步");Content("2 : 错误!重新选择");End();sure = Console.ReadLine();
}while (string.IsNullOrEmpty(sure) || (sure != "1" && sure != "2"))
{Content(@$"【{_dbarr[(int)dbstr]}】【{_syncarr[(int)type]}】");All("请重新输入有效的值!");sure = Console.ReadLine();
}if (sure == "1")
{SqlSugarClient Db = new(new ConnectionConfig(){ConnectionString = @$"Server=.;User Id={user};Password={pwd};Database={_dbarr[(int)dbstr]}",//数据库链接字符串DbType = DbType.SqlServer,//指定数据库类型IsAutoCloseConnection = true,//链接使用完后是否自动释放InitKeyType = InitKeyType.Attribute,//从实体特性中读取主键自增列信息ConfigureExternalServices = new ConfigureExternalServices(){EntityNameService = (type, entity) =>{entity.IsDisabledDelete = true;//全局禁止删除列}}});All("开始同步!请勿关闭程序...  ");switch (_syncarr[(int)type]){case "DBFirst":// 应用程序所在目录,即bin/debug//方法1、Environment.CurrentDirectory 取得或设置当前工作目录的完整限定路径//方法2、AppDomain.CurrentDomain.BaseDirectory 获取基目录,它由程序集冲突解决程序用来探测程序集DirectoryInfo exePath = new(Environment.CurrentDirectory);string pathFullName = exePath.Parent.Parent.Parent.FullName;//项目所在目录,即项目最外层目录Db.DbFirst.IsCreateAttribute().CreateClassFile(@$"{pathFullName}\\Model\\DBEntity", "Model.DBEntity");//文件地址,指定实体命名空间break;case "CodeFirst":Type[] types = Assembly.LoadFrom("DBSyncTool.dll")//如果 .dll报错,可以换成 xxx.exe 有些生成的是exe .GetTypes().Where(it => it.FullName.Contains("Model.DBEntity"))//命名空间过滤,当然你也可以写其他条件过滤.ToArray();//断点调试一下是不是需要的Type,不是需要的在进行过滤//同步数据表结构Db.DbMaintenance.CreateDatabase();Db.CodeFirst.SetStringDefaultLength(1024).InitTables(types);//多表同步break;case "AddDataBase":string? dbs = "";WDBS:Content(@$"请输入要新增的数据库名称");dbs = Console.ReadLine();if (string.IsNullOrEmpty(dbs)){All("请重新输入有效的值!");goto WDBS;}Db = new(new ConnectionConfig(){ConnectionString = @$"Server=.;User Id={user};Password={pwd};Database={dbs}",//数据库链接字符串DbType = DbType.SqlServer,//指定数据库类型IsAutoCloseConnection = true,//链接使用完后是否自动释放InitKeyType = InitKeyType.Attribute,//从实体特性中读取主键自增列信息});Db.DbMaintenance.CreateDatabase();break;}
}
else
{ReStart();goto ChooseDB;
}
All("...   ...   ...");
All("结束同步!已自动关闭程序...");
Console.ReadKey();

!!!请注意如下图中对应的命名空间和文件夹名称

 

这篇关于五、SQLSugar 配置实体(CodeFirstDBFirst)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/605084

相关文章

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

IDEA配置Tomcat远程调试

因为不想把本地的Tomcat配置改乱或者多人开发项目想测试,本文主要是记录一下,IDEA使用Tomcat远程调试的配置过程,免得一段时间不去配置到时候忘记(毕竟这次是因为忘了,所以才打算记录的…) 首先在catalina.sh添加以下内容 JAVA_OPTS="-Dcom.sun.management.jmxremote=-Dcom.sun.management.jmxremote.port

Steam邮件推送内容有哪些?配置教程详解!

Steam邮件推送功能是否安全?如何个性化邮件推送内容? Steam作为全球最大的数字游戏分发平台之一,不仅提供了海量的游戏资源,还通过邮件推送为用户提供最新的游戏信息、促销活动和个性化推荐。AokSend将详细介绍Steam邮件推送的主要内容。 Steam邮件推送:促销优惠 每当平台举办大型促销活动,如夏季促销、冬季促销、黑色星期五等,用户都会收到邮件通知。这些邮件详细列出了打折游戏、

微信小程序开发必知必会:文件结构和基本配置

一、微信小程序基本文件结构 1.  project.config.json:项目的基本配置文件,包括项目名称、appid、项目目录、页面文件夹等。     {"setting": {"urlCheck": false,"es6": true,"postcss": true,"nodeModulesPath": "D:\\\\node_modules"},"appid": "wxd678e

【杂记-浅谈DHCP动态主机配置协议】

DHCP动态主机配置协议 一、DHCP概述1、定义2、作用3、报文类型 二、DHCP的工作原理三、DHCP服务器的配置和管理 一、DHCP概述 1、定义 DHCP,Dynamic Host Configuration Protocol,动态主机配置协议,是一种网络协议,主要用于在IP网络中自动分配和管理IP地址以及其他网络配置参数。 2、作用 DHCP允许计算机和其他设备通

Pycharm配置conda环境(解决新版本无法识别可执行文件问题)

引言: 很多小伙伴在下载最新版本的pycharm或者更新到最新版本后为项目配置conda环境的时候,发现文件夹目录中无法显示可执行文件(一般为python.exe),以下就是本人遇到该问题后试验和解决该问题的一些方法和思路。 一般遇到该问题的人群有两种,一种是刚入门对pycharm进行conda环境配置的小白(例如我),不熟悉相关环境配置的操作和过程,还有一种是入坑pycharm有段时间的老手

【zabbix】zabbix客户端配置

1、部署zabbix客户端 #zabbix 5.0 版本采用 golang 语言开发的新版本客户端 agent2 。#zabbix 服务端 zabbix_server 默认使用 10051 端口,客户端 zabbix_agent2 默认使用 10050 端口。systemctl disable --now firewalldsetenforce 0hostnamectl set-host

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host:

众所周知,配置即代码≠基础设置即代码

​前段时间翻到几条留言,问: “配置即代码和基础设施即代码一样吗?” “配置即代码是什么?怎么都是基础设施即代码?” 我们都是知道,DevOp的快速发展,让服务器管理与配置的时间大大减少,配置即代码和基础设施即代码作为DevOps的重要实践,在其中起到了关键性作用。 不少人将二者看作是一件事,配置即大代码是关于管理特定的应用程序配置设置本身,而基础设施即代码更关注的是部署支持应用程序环境所需的