(精华)2020年8月11日 C#基础知识点 数据库自动生成实体类

举报
愚公搬代码 发表于 2021/10/19 23:30:07 2021/10/19
【摘要】 数据库相关的sql //获取所有的数据库名 private static string GetAllDataSql = "SELECT NAME FROM MASTER.DBO.SYSDATABASES...

数据库相关的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 ";


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

模型相关方法

//根据表名创建模型
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();
			}
		}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
//根据数据库直接生成所有模型
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());
				}
			}
		}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

其他辅助类

//获取列的类型
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("无此类型");
		}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

文章来源: codeboy.blog.csdn.net,作者:愚公搬代码,版权归原作者所有,如需转载,请联系作者。

原文链接:codeboy.blog.csdn.net/article/details/107927969

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。