(에센스) 2020 년 8 월 11 일 C \ # 기초 지식 포인트 데이터베이스 자동 생 성 실체 클래스
//
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
{{\r
");
while (reader.Read())
{
stringBuilder.Append($" public {GetTypeOfColumn(reader["typeName"].ToString(), reader["isnullAble"].ToString())} {reader["columnName"]} {{get;set;}}\r
");
}
stringBuilder.Append("} \r
");
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(" ");
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
WebView2를 Visual Studio 2017 Express에서 사용할 수 있을 때까지Evergreen .Net Framework SDK 4.8 VisualStudio2017에서 NuGet을 사용하기 때문에 패키지 관리 방법을 packages.config 대신 PackageReference를 사용해야...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.