(精华)2020年8月11日 C#基础知识点 数据库自动生成实体类
发布日期:2021-06-29 15:09:12
浏览次数:2
分类:技术文章
本文共 3348 字,大约阅读时间需要 11 分钟。
数据库相关的sql
//获取所有的数据库名private static string GetAllDataSql = "SELECT NAME FROM MASTER.DBO.SYSDATABASES ORDER BY NAME";//获取所有的表名private static string GetAllTableSql = "SELECT name FROM sys.tables where type ='U'";//获取所有的表信息private static string GetTableInfoSql = @"SELECT DISTINCT a.COLUMN_NAME columnName, a.DATA_TYPE typeName, a.IS_NULLABLE isnullAble From INFORMATION_SCHEMA.Columns a LEFT JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE b ON a.TABLE_NAME=b.TABLE_NAME ";
模型相关方法
//根据表名创建模型public static void CreateSingleModel(string tableName) { string sql = $"{GetTableInfoSql} where a.table_name='{tableName}'"; using (SqlConnection conn = new SqlConnection(ConnectionString))//ConnectionString为自己连接字符串 { SqlCommand sqlCommand = new SqlCommand(sql, conn); conn.Open(); SqlDataReader reader = sqlCommand.ExecuteReader(); StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append($"public class {tableName} \r\n{ {\r\n"); while (reader.Read()) { stringBuilder.Append($" public {GetTypeOfColumn(reader["typeName"].ToString(), reader["isnullAble"].ToString())} {reader["columnName"]} { {get;set;}}\r\n"); } stringBuilder.Append("} \r\n"); string directory = string.IsNullOrEmpty(StaticConfiguration.FieldPath) ? AppDomain.CurrentDomain.BaseDirectory + "\\Model\\": FieldPath;//FieldPath为自己文件路径 StreamWriter sr; //是否存在文件夹,不存在则创建 if (!Directory.Exists(directory)) { Directory.CreateDirectory(directory); } string path = directory + "\\" + tableName + ".txt"; //如果该文件存在则追加内容,否则创建文件 if (File.Exists(path)) { sr = File.AppendText(path); } else { sr = File.CreateText(path); } sr.Write(stringBuilder.ToString()); sr.Flush(); sr.Close(); } }
//根据数据库直接生成所有模型public static void BatchCreateModel() { using (SqlConnection conn = new SqlConnection(ConnectionString))//ConnectionString为自己连接字符串 { SqlCommand sqlCommand = new SqlCommand(GetAllTableSql, conn); conn.Open(); SqlDataReader reader = sqlCommand.ExecuteReader(); while (reader.Read()) { CreateSingleModel(reader["name"].ToString()); } } }
其他辅助类
//获取列的类型private static string GetTypeOfColumn(string type, string nullAble) { if (type.Equals("int") && nullAble.Equals("NO")) return "int"; else if (type.Equals("int") && nullAble.Equals("YES")) return "int?"; else if (type.Equals("bit") && nullAble.Equals("Not")) return "bool"; else if (type.Equals("bit") && nullAble.Equals("YES")) return "bool?"; else if ((type.Equals("decimal")|| type.Equals("numeric")|| type.Equals("float") || type.Equals("real")) && nullAble.Equals("NO")) return "decimal"; else if ((type.Equals("decimal") || type.Equals("numeric") || type.Equals("float") || type.Equals("real")) && nullAble.Equals("Yes")) return "decimal?"; else if (type.Equals("datetime") && nullAble.Equals("YES")) return "DateTime?"; else if (type.Equals("datetime") && nullAble.Equals("NO")) return "DateTime"; else if (type.Equals("nchar") || type.Equals("char") || type.Equals("nvarchar") || type.Equals("varchar") || type.Equals("text")) return "string"; else throw new Exception("无此类型"); }
转载地址:https://codeboy.blog.csdn.net/article/details/107927969 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
很好
[***.229.124.182]2024年04月24日 17时19分18秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
美国无人机在火星首飞成功,创造历史,3米飞行高度悬停30秒
2019-04-29
缺货涨价很久的MCU的国产和国外厂家汇总!(80家)
2019-04-29
华为重磅反击,鸿蒙来了!
2019-04-29
常用电子接口大全,遇到不认识的,就翻出来对照辨认!
2019-04-29
芯片IC附近为啥要放0.1uF的电容?
2019-04-29
电赛 | 19年全国一等奖,北航学子回忆录。
2019-04-29
电赛 | 19年全国一等奖,北航学子回忆录(上)
2019-04-29
电赛 | 19年全国一等奖,北航学子回忆录(下)
2019-04-29
突破!台积电1nm芯片,有了新进展。
2019-04-29
一文读懂全系列树莓派!
2019-04-29
自制一个害羞的口罩,见人就闭嘴,戴着可以喝奶茶
2019-04-29
聊聊我是如何编程入门的
2019-04-29
J-Link该如何升级固件?
2019-04-29
485通信自动收发电路,历史上最详细的解释
2019-04-29
一位头发发白的神人教你怎么写程序,运维,买电脑,写文章,平面设计!
2019-04-29
「第三篇」全国电子设计竞赛,这些你必须知道的比赛细节,文末附上近十年电赛题目下载...
2019-04-29
5G小科普(漫画版,So easy!)
2019-04-29
「第四篇」电赛控制题可以准备一些什么?
2019-04-29
「第六篇」对于电赛,我们应该看重什么?
2019-04-29
树莓派翻车了
2019-04-29