(精华)2020年8月11日 C#基础知识点 数据库自动生成实体类
【摘要】
数据库相关的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)