Web开发:ORM框架之使用Freesql的DbFrist封装常见功能

一、调用

public class Program
{static string connectionstring  = "连接字符串(数据库名)";static void Main(string[] args){//1.连接数据库var freesql = new FreeSqlBuilder().UseConnectionString(DataType.SqlServer, connectionstring)//连接数据库//.UseMonitorCommand(cmd => Console.Write(cmd.CommandText))//打印SQL.Build();//2.数据库=>C#实体List<string> tablenames = new List<string> { {"数据表1"} , {"数据表2"} };string entitystring = GetEntitystring(freesql,tablenames);Console.WriteLine(entitystring);}}

二、封装

public class CsProperty
{public string Name { get; set; }//字段名称public string DefaultValue { get; set; }//默认值,例如"123"(string带双引号的),123(int decimal bool不带引号的)public string CsType { get; set; }//cs类型,形如int?public string Comment { get; set; }//注释public string Property { get; set; }//属性模板,形如public int Id { get; set; }}
public static class Logical
{// 表字段注释(只支持单表)public static string GetTableComment(IFreeSql fsql, string tablename, string filed){var tableinfo = fsql.DbFirst.GetTableByName(tablename);var tablelist = ChangeCsType(tableinfo.Columns.ToList());var tablecomment = tableinfo.Comment;StringBuilder sb = new StringBuilder();sb.Append($"【表({tablename})】注释:{tablecomment}\n");sb.Append($"【字段】注释:\n");foreach (var item in tablelist){sb.Append($"【{item.Name}({item.CsType})】{item.Comment}\n");}string CommonSQL = $@"--添加表注释
EXEC sys.sp_addextendedproperty 
@name = N'MS_Description', 
@value = N'你的注释语', 
@level0type = N'SCHEMA', @level0name = N'dbo', 
@level1type = N'TABLE',  @level1name = N'{tablename}', 
@level2type = N'COLUMN', @level2name = N'{filed}';
--修改表注释
EXEC sys.sp_updateextendedproperty 
@name = N'MS_Description', 
@value = N'新的注释语', 
@level0type = N'SCHEMA', @level0name = N'dbo', 
@level1type = N'TABLE',  @level1name = N'{tablename}', 
@level2type = N'COLUMN', @level2name = N'{filed}';";sb.Append($"\n\n{CommonSQL}");return sb.ToString();}//生成实体类的方法public static string GetEntityGrammar(IFreeSql freesql, List<string> tablenames){string output = "";foreach (var tablename in tablenames){string result = $"[Table(\"{tablename}\")]\npublic class {tablename} : AuditedAggregateRoot<int> \n{{\n";var tableInfo = freesql.DbFirst.GetTableByName(tablename);foreach (var item in tableInfo.Columns.OrderBy(x => x.Position)){var cstype = item.CsType.Name.ToLower();//获取类型if (cstype.StartsWith("int")){cstype = "int";}else if (cstype.Equals("datetime")){cstype = "DateTime";}else if (cstype.Equals("boolean")){cstype = "bool";}//获取是否可为空if (!cstype.Equals("string") && item.IsNullable){cstype += "?";}//获取注释,套入属性模板string feild = "";if (!string.IsNullOrEmpty(item.Comment)){feild += $"    /// <summary>\n    ///  {item.Comment}\n    /// </summary>\n";}feild += $"    public {cstype} {item.Name} {{ get; set; }}\n";result += feild;}result += "}";output += result + "\n";}return output;}//生成创建实体的方法public static string GetBuildEntity(IFreeSql freesql, List<string> tablenames){if (tablenames.Count == 0){return null;}string output = "";StringBuilder sb_en = new StringBuilder();StringBuilder sb_lt = new StringBuilder();foreach (var tablename in tablenames){var tableInfo = freesql.DbFirst.GetTableByName(tablename);var tablelist = ChangeCsType(tableInfo.Columns.ToList());sb_en.Append($"var {tablename.ToLower()} = new {tablename}\n{{\n");sb_lt.Append($"List<{tablename}> destictlist = new List<{tablename}>();\n");sb_lt.Append($"foreach (var item in sourcelist)\n{{\n");sb_lt.Append($"\tvar entity = new {tablename}();\n");int index = 0;foreach (var item in tablelist){bool isLast = index == tablelist.Count - 1;if (isLast){sb_en.Append($"\t{item.Name} = {item.DefaultValue}\n");}else{sb_en.Append($"\t{item.Name} = {item.DefaultValue},\n");}sb_lt.Append($"\tentity.{item.Name} = item.{item.Name};\n");index++;}sb_en.Append($"}};\n");sb_lt.Append($"\tdestictlist.Add(entity);\n}}");}output = sb_en.ToString() + "\n\n" + sb_lt.ToString();return output;}//生成实体字段分类的方法public static string GetEntityFeildsClassify(IFreeSql freesql, List<string> tablenames){string output = "";foreach (var tablename in tablenames){var tableColumns = freesql.DbFirst.GetTableByName(tablename)?.Columns.OrderBy(x => x.Position);//item.CsType.Name.ToLower();var grouplist = tableColumns?.GroupBy(x => x.CsType.Name.ToLower()).Select(list => (Key: list.Key.ToString(), List: list.Select(x => x.Name)));output += $"【{tablename}全部字段】\n";output += $"{string.Join("\n", tableColumns.Select(x => x.Name))}\n";foreach (var item in grouplist){output += $"【{item.Key}】\n";output += $"{string.Join("\n", item.List)}\n";}output += "\n";}return output;}//根据表名获取表的详细信息public static string GetTableDetails(IFreeSql freesql, List<string> tablenames){StringBuilder result = new StringBuilder();foreach (var tablename in tablenames){var detail = freesql.DbFirst.GetTableByName(tablename);result.Append($"表名称:{detail.Name}\n");result.Append($"表注释:{(string.IsNullOrEmpty(detail?.Comment) ? "无表注释" : detail?.Comment)}\n");result.Append($"表主键:{detail?.Primarys.FirstOrDefault()?.Name ?? "无表主键"}\n");result.Append($"表的自增列:{detail?.Identitys.FirstOrDefault()?.Name ?? "无自增列"}\n");result.Append($"表的字段数:{detail.Columns.Count}\n");result.Append($"表的索引数:{detail.Indexes.Count}\n");int index = 0;foreach (var item in detail.Indexes){index++;result.Append($"索引编号{index}:");string indexcontent = "";foreach (var jtem in item.Columns){indexcontent += jtem?.Column?.Name + ",";}result.Append($"{indexcontent.Trim(',')}\n");}result.Append("\n");}return result.ToString();}//随机插入数据public static string InsertRandomData(IFreeSql freesql, List<string> tablenamelist, int count){foreach (var tablename in tablenamelist){// 获取表的结构信息var tableInfo = freesql.DbFirst.GetTableByName(tablename);// 构建字段名和占位符var fieldNames = string.Join(",", tableInfo.Columns.Where(x => !x.IsIdentity).OrderBy(x => x.Position).Select(c => c.Name));var valuesBuilder = new StringBuilder();// 随机数生成器Random random = new Random();// 执行插入for (int i = 0; i < count; i++){StringBuilder valueBuilder = new StringBuilder();foreach (var item in tableInfo.Columns.Where(x => !x.IsIdentity).OrderBy(x => x.Position)){var cstype = item.CsType.Name.ToLower();object defaultValue = null;if (cstype.Equals("string")){defaultValue = item.MaxLength <= 20 ? $"数据{i}" : $"模拟测试数据{i}";}else if (cstype.StartsWith("int") || cstype.StartsWith("decimal")){defaultValue = random.Next(0, 1000); // 随机整数}else if (cstype.Equals("datetime")){defaultValue = DateTime.Now.AddDays(random.Next(-30, 0)); // 随机日期}else if (cstype.Equals("boolean")){defaultValue = random.Next(0, 2) == 1; // 随机布尔值}else{defaultValue = DBNull.Value; // 未处理的其他类型}// 处理值为 null 或 DBNull 的情况if (defaultValue == null || defaultValue == DBNull.Value){valueBuilder.Append("NULL,");}else if (cstype.Equals("string")){valueBuilder.Append($"'{defaultValue}',");}else if (cstype.Equals("datetime")){valueBuilder.Append($"'{((DateTime)defaultValue):yyyy-MM-dd HH:mm:ss}',");}else{valueBuilder.Append($"{defaultValue},");}}// 去掉最后一个逗号valueBuilder.Length--;// 构建完整的 SQL 插入语句string insertSql = $"INSERT INTO {tablename} ({fieldNames}) VALUES ({valueBuilder})";// 执行插入操作var effectcount = freesql.Ado.ExecuteNonQuery(insertSql);}}return $"执行插入到表【{string.Join(",", tablenamelist)}】成功!各自插入了【{count}】条数据!";}//返回多个表的共有字段public static string GetTablesPublicFeilds(IFreeSql freesql, List<string> tablenamelist){if (tablenamelist.Count == 0 || tablenamelist.Count == 1){return null;}List<string> last = new List<string>();List<DbColumnInfo> storage = new List<DbColumnInfo>();List<DbColumnInfo> dbinfo = new List<DbColumnInfo>();foreach (var item in tablenamelist){dbinfo = freesql.DbFirst.GetTableByName(item).Columns.ToList();var tablefeilds = dbinfo.Select(x => x.Name).ToList();last = last.Count == 0 ? tablefeilds : tablefeilds.Intersect(last).ToList();}storage = dbinfo.Where(x => last.Contains(x.Name)).ToList();var counts = "总数是:" + storage.Count + "\n";var allfeilds = string.Join("\n", last);var changeinfo = ChangeCsType(storage);var showfeilds = string.Join("\n", changeinfo.Select(x => x.Property).ToList());return counts + allfeilds + "\n\n" + showfeilds;}//返回多个表的全部字段(去重复)public static string GetTablesAllFeilds(IFreeSql freesql, List<string> tablenamelist){if (tablenamelist.Count == 0 || tablenamelist.Count == 1){return null;}List<string> last = new List<string>();List<DbColumnInfo> storage = new List<DbColumnInfo>();List<DbColumnInfo> dbinfo = new List<DbColumnInfo>();foreach (var item in tablenamelist){dbinfo = freesql.DbFirst.GetTableByName(item).Columns.ToList();var tablefeilds = dbinfo.Select(x => x.Name).ToList();last.AddRange(tablefeilds);storage.AddRange(dbinfo);}last = last.Distinct().ToList();storage = storage.Distinct().ToList();storage = storage.Where(x => last.Contains(x.Name)).ToList();var counts = "总数是:" + last.Count + "\n";var allfeilds = string.Join("\n", last);var changeinfo = ChangeCsType(storage);var showfeilds = string.Join("\n", changeinfo.Select(x => x.Property).Distinct().ToList());return counts + allfeilds + "\n\n" + showfeilds;}//返回两表的独有字段public static string GetTwoTablesUniqueFeilds(IFreeSql freesql, List<string> tablenamelist){if (tablenamelist.Count != 2){return $"您输入了{tablenamelist.Count}个表,该功能只支持两表查询!";}var aname = tablenamelist[0];var bname = tablenamelist[1];var alist = freesql.DbFirst.GetTableByName(aname).Columns;var blist = freesql.DbFirst.GetTableByName(bname).Columns;var a_feilds = alist.Select(x => x.Name);var b_feilds = blist.Select(x => x.Name);var a_unique_feilds = a_feilds.Except(b_feilds);var b_unique_feilds = b_feilds.Except(a_feilds);var a_unique_cols = alist.Where(x => a_unique_feilds.Contains(x.Name)).ToList();var b_unique_cols = blist.Where(x => b_unique_feilds.Contains(x.Name)).ToList();var aUniqueList = ChangeCsType(a_unique_cols);var bUniqueList = ChangeCsType(b_unique_cols);StringBuilder result = new StringBuilder();StringBuilder result2 = new StringBuilder();result.Append($"{aname}的独有字段是:\n");result2.Append($"{aname}的独有字段是:\n");foreach (var item in aUniqueList){result.Append($"{item.Name}({item.CsType})\n");result2.Append(item.Property + "\n");}result.Append($"\n{bname}的独有字段是:\n");result2.Append($"\n{bname}的独有字段是:\n");foreach (var item in bUniqueList){result.Append($"{item.Name}({item.CsType})\n");result2.Append(item.Property + "\n");}string output = result.ToString() + "\n" + result2.ToString();return output;}//将列转化为Cs类型表达式public static List<CsProperty> ChangeCsType(List<DbColumnInfo> list){List<CsProperty> result = new List<CsProperty>();foreach (var item in list.OrderBy(x => x.Position)){CsProperty en = new CsProperty();en.Name = item.Name;en.Comment = item.Comment;en.DefaultValue = item.DefaultValue;var cstype = item.CsType.Name.ToString().ToLower();var random = new Random();var rnum = random.Next(0, 9999);if (cstype.Equals("string")){en.DefaultValue = item.MaxLength <= 10 ? $"\"默认值\"" : $"\"默认值数据{rnum}\"";en.CsType = "string";}else if (cstype.StartsWith("int")){en.DefaultValue = rnum.ToString();en.CsType = "int" + $"{(item.IsNullable ? "?" : "")}";}else if (cstype.StartsWith("decimal")){en.DefaultValue = rnum.ToString();en.CsType = "decimal" + $"{(item.IsNullable ? "?" : "")}";}else if (cstype.Equals("datetime")){en.DefaultValue = "DateTime.Now"; //  今天日期en.CsType = "DateTime" + $"{(item.IsNullable ? "?" : "")}";}else if (cstype.Equals("boolean")){en.DefaultValue = (random.Next(0, 2) == 1).ToString(); // 随机布尔值en.CsType = "bool";}else{en.DefaultValue = "未知";en.CsType = item.CsType.Name.ToLower();}en.Property = $"public {en.CsType} {en.Name} {{ get; set; }}";result.Add(en);}return result;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/474668.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【支持向量机(SVM)】:算法原理及核函数

文章目录 1 SVM算法原理1.1 目标函数确定1.2 约束条件优化问题转换1.3 对偶问题转换1.4 确定超平面1.5 计算举例1.6 SVM原理小节 2 SVM核函数2.1 核函数的作用2.2 核函数分类2.3 高斯核函数2.3 高斯核函数API2.4 超参数 γ \gamma γ 1 SVM算法原理 1.1 目标函数确定 SVM思想…

mysql bin log分析

centos7 部署collabora office (yum版 与 docker)_collabora office部署-CSDN博客 1.下载polardb的bin log文件 show binary logs; mysqlbinlog -u 用户名 -p -h 地址 --read-from-remote-server --raw mysql-bin.001768 mysqlbinlog --no-defaults --databasexxx --base64-…

初识进程——Linux

目录 概述 进程控制块 指令知识补充 标识符函数 /proc 目录介绍 /proc/&#xff08;pid&#xff09; cwd exe&#xff1a; fork 结束语 概述 进程是程序执行的实体&#xff0c;两者之间有着密切联系。程序是静态的代码与指令集合&#xff0c;每次运行程序都会创建新的进程…

湘潭大学软件工程算法设计与分析考试复习笔记(三)

回顾 湘潭大学软件工程算法设计与分析考试复习笔记&#xff08;一&#xff09;湘潭大学软件工程算法设计与分析考试复习笔记&#xff08;二&#xff09; 前言 现在继续开始复习。每天复习一点点&#xff0c;嘿嘿。今天本来准备写一个动态规划的题的&#xff0c;感觉半懂不懂…

109. UE5 GAS RPG 实现检查点的存档功能

在这一篇文章里&#xff0c;我们接着实现存档的功能&#xff0c;保存当前玩家的生成位置&#xff0c;游戏里有很多中方式去实现玩家的位置存储&#xff0c;这里我们采用检查点的方式&#xff0c;当玩家接触到当前检查点后&#xff0c;我们可以通过检查点进行保存玩家的状态&…

如何创建一个项目用于研究element-plus的原理

需求&#xff1a;直接使用element-plus未封装成组件的源码&#xff0c;创建一个项目&#xff0c;可以使用任意的element-plus组件&#xff0c;可以深度研究组件的运行。例如研究某一个效果&#xff0c;如果直接在node_modules修改elment-plus打包之后的那些js、mjs代码&#xf…

机器学习day7-线性回归3、逻辑回归、聚类、SVC

7欠拟合与过拟合 1.欠拟合 模型在训练数据上表现不佳&#xff0c;在新的数据上也表现不佳&#xff0c;常发生在模型过于简单无法处理数据中的复杂模式时。 特征&#xff1a; 训练误差较高 测试误差也高 模型过于简化&#xff0c;不能充分学习训练数据中的模式 2.过拟合 …

反向代理模块

1 概念 1.1 反向代理概念 反向代理是指以代理服务器来接收客户端的请求&#xff0c;然后将请求转发给内部网络上的服务器&#xff0c;将从服务器上得到的结果返回给客户端&#xff0c;此时代理服务器对外表现为一个反向代理服务器。 对于客户端来说&#xff0c;反向代理就相当于…

STM32 独立看门狗(IWDG)详解

目录 一、引言 二、独立看门狗的作用 三、独立看门狗的工作原理 1.时钟源 2.计数器 3.喂狗操作 4.超时时间计算 5.复位机制 四、独立看门狗相关寄存器 1.键寄存器&#xff08;IWDG_KR&#xff09; 2.预分频寄存器&#xff08;IWDG_PR&#xff09; 3.重载寄存器&…

足球虚拟越位线技术FIFA OT(二)

足球虚拟越位线技术FIFA OT&#xff08;二&#xff09; 在FIFA认证测试过程中&#xff0c;留给VAR系统绘制越位线的时间只有90秒&#xff08;在比赛中时间可能更短&#xff09;&#xff0c;那么90秒内要做什么事呢&#xff0c;首先场地上球员做出踢球动作&#xff0c;然后VAR要…

MySQL数据库3——函数与约束

一.函数 1.字符串函数 MySQL中内置了很多字符串函数&#xff0c;常用的几个如下&#xff1a; 使用方法&#xff1a; SELECT 函数名(参数);注意&#xff1a;MySQL中的索引值即下标都是从1开始的。 2.数值函数 常见的数值函数如下&#xff1a; 使用方法&#xff1a; SELECT…

Proteus 8.17的详细安装教程

通过百度网盘分享的文件&#xff1a;Proteus8.17(64bit&#xff09;.zip 链接&#xff1a;https://pan.baidu.com/s/1zu8ts1Idhgg9DGUHpAve7Q 提取码&#xff1a;8q8v 1.右击【Proteus8.17(64bit&#xff09;.zip】&#xff0c;选择【全部解压缩......】。 &#xff0c; 2.…

MySQL安装及数据库基础

目录 一. MySQL下载安装 1.1 安装&#xff08;如果之前有安装过MySQL&#xff0c;先执行下面的卸载流程&#xff09; 1.1.1 更新系统的软件包列表 1.1.2 安装MySQL服务器 1.1.3 检查MySQL服务是否启动&#xff0c;若没有启动手动启动 1.1.4 登录MySQL&#x…

NavVis VLX3的精度怎么去进行验证?【上海沪敖3D】

01、精度评价现状 三维捕捉行业还没有建立一个用于估算或验证移动激光扫描系统精度的统一标准。因此&#xff0c;需要高精度交付成果的专业人士很难相信设备所标注的精度规格&#xff0c;也就很难知道基于SLAM的移动激光扫描系统是否适合当前的项目。 NavVis将通过展示一种严格…

css3新特性(二十六课)

1、css3盒子模型 box - sizing: content - box&#xff1b; 是 CSS 中用于定义盒模型宽度和高度计算方式的一个属性值。在这种盒模型下&#xff0c;元素的宽度和高度&#xff08;width和height属性&#xff09;仅包括内容区域&#xff08;content&#xff09;的大小&#xff…

macbook外接2k/1080p显示器调试经验

准备工具 电脑 满足电脑和显示器要求的hdmi线或者转接头或者扩展坞 betterdisplay软件 Dell P2419H的最佳显示信息如下 飞利浦 245Es 2K的最佳显示比例如下 首选1152

【Hadoop】【大数据技术基础】实践三 NoSQL数据库 大数据基础编程、实验和案例教程(第2版)

第6章 典型NoSQL数据库的安装和使用 Redis安装和使用MongoDB的安装和使用 6.1 Redis安装和使用 6.1.1 Redis简介 Redis是一个键值&#xff08;key-value&#xff09;存储系统&#xff0c;即键值对非关系型数据库&#xff0c;和Memcached类似&#xff0c;目前正在被越来越多的…

零基础Java第二十二期:异常(二)

目录 一、异常的捕获 1.1. 多个异常&#xff0c;一次捕获 1.2. 异常之间的父子关系 1.3. finally 二、自定义异常 一、异常的捕获 1.1. 多个异常&#xff0c;一次捕获 由于Exception类是所有异常类的父类&#xff0c;因此可以用这个类型表示捕捉所有异常。也就是说&am…

IO流(九):打印流-字节打印流PrintStream、字符打印流PrintWriter

目录 1、什么是打印流&#xff1f; 2、字节打印流-PrintStream 2.1 代码演示以及注释 2.2 演示几种字节打印流常用的创建方式 3、字符打印流-PrintWriter 3.1 代码演示以及注释 3.2 演示几种字符打印流常用的创建方式 4、案例-System.out.println();输出内容重定向到指…

如何将几个音频合成一个音频?非常简单的几种合成方法

如何将几个音频合成一个音频&#xff1f;音频合成不仅仅是将不同的音频文件按顺序排列&#xff0c;它还可能涉及到音量调节、剪辑、淡入淡出、音效调整等多个方面。对于一些专业的音频制作人员来说&#xff0c;音频的每一部分细节都可能需要精心打磨&#xff0c;以确保最终合成…