
·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> 如何写代码生成器
---恢复内容开始---
代码生成器的原理很简单,就是通过读取数据库的表结构,根据读取到的数据组合成代码,一个最基础的代码生成器有以下几点
一 生成器界面,我用的是winform,界面如图

第一行是数据库链接字符串,点击右边的测试连接,就可以测试数据库链接字符串是否正确。
如果测试链接成功后,自动抓取数据库的所有表,将表名抓取到表名的下拉框中,表名的下拉框也变成可编辑的,右侧的主键的下拉框,也会默认抓取左侧表的主键。
点击【生成代码】按钮,生成代码到下面的文本框中
点击【生成文件】按钮,生成代码到对应的cs文件下,文件路径为保存路径加表名
二 代码解释
1.抓取数据库中所有的表,核心代码如下:
//获得数据库所有表名
string sql = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'";
dt = ResultDataTable(sql);
//表名
string[] tables = new string[dt.Rows.Count];
for (int i = 0; i < dt.Rows.Count; i++)
{
DataRow row = dt.Rows[i];
tables[i] = (string)row["TABLE_NAME"];
}
//把表名放在下拉框中
cmbTables.DataSource = tables;
cmbTables.SelectedIndex = 0;
ResultDataTable方法如下:
public DataTable ResultDataTable(string sql, params SqlParameter[] parameters)
{
using (SqlConnection connstr = new SqlConnection(txtConnStr.Text))
{
//打开数据库连接
connstr.Open();
using (SqlCommand command = connstr.CreateCommand())
{
command.CommandText = sql;
command.Parameters.AddRange(parameters);
SqlDataAdapter sda = new SqlDataAdapter(command);
DataSet ds = new DataSet();
//获取表中的全部信息(如填充每个表中的主键和外键等)
sda.FillSchema(ds, SchemaType.Source);
sda.Fill(ds);
return ds.Tables[0];
}
}
}
2.生成代码到文本框中,先通过表名获取表的所有列,然后根据所有的列生成代码
//获取表名 string tableName = cmbTables.SelectedValue.ToString(); //获取字段名 DataColumnCollection columns = Returncolumns(tableName); //将生成的代码填入文本框中 txtCode.Text = CreateModelCode(columns);
根据表名返回表中所有列名的方法Returncolumns
/// <summary>
/// 返回数据表列名
/// </summary>
/// <param name="tablename">表名</param>
/// <returns></returns>
public DataColumnCollection Returncolumns(string tablename)
{
DataTable datatable = ResultDataTable("select top 0 * from " + tablename);
DataColumnCollection columns = datatable.Columns;
return columns;
}
根据列名生成代码的方法CreateModelCode()。这个方法是生成的实体类,因为生成实体类最简单,所以用这个做例子。。。
/// <summary>
/// 生成Model代码
/// </summary>
/// <param name="columns"></param>
public string CreateModelCode(DataColumnCollection columns)
{
StringBuilder sb = new StringBuilder();
sb.Append("public class ").AppendLine(cmbTables.SelectedValue.ToString()).AppendLine("{");
foreach (DataColumn column in columns)
{
sb.Append(" public ").Append(ColumnType(column)).Append(" ");//例如 public string
sb.Append(column.ColumnName); //例如 public string Id
sb.AppendLine(" { get; set; }");//例如 public string Id { get; set;}
}
sb.Append("}");
return sb.ToString();
}
3.生成代码到CS文件中,实现方式跟输入到文本框中是一样的,只不过最后一步是生成一个新的文件,主要代码:
//判断文件目录是否存在
string directory = txtDir.Text.Trim();
if (string.IsNullOrWhiteSpace(directory))
{
MessageBox.Show("请输入文件地址");
return;
}
if (!Directory.Exists(directory))
{
MessageBox.Show("路径不对,请重新输入");
}
string tableName = cmbTables.SelectedValue.ToString();
DataColumnCollection columns = Returncolumns(tableName);
string fileName = tableName + ".cs";
string filePath = directory + "\\" + fileName;
string fileStr = CreateModelCode(columns);
try
{
MyCommonTools.WriteToFile(filePath, fileStr, true);
MessageBox.Show("生成成功");
}
catch (Exception exception)
{
MessageBox.Show("生成代码出错");
throw exception;
}
WriteToFile()方法代码在下面:
/// <summary>
/// 将字符串写入到文件中
/// </summary>
/// <param name="filePath">文件的实际路径</param>
/// <param name="content">内容</param>
/// <param name="isCover">是否覆盖,true就是重新写一遍,false就是往里面添加内容</param>
public static void WriteToFile(string filePath, string content, bool isCover)
{
FileStream fs = null;
try
{
if (!isCover && System.IO.File.Exists(filePath))
{
fs = new FileStream(filePath, FileMode.Append, Fileaccess.Write);
StreamWriter sw = new StreamWriter(fs, Encoding.UTF8);
sw.WriteLine(content);
sw.Flush();
sw.Close();
}
else
{
System.IO.File.WriteAllText(filePath, content, Encoding.UTF8);
}
}
finally
{
if (fs != null)
{
fs.Close();
}
}
}
代码:http://files.cnblogs.com/files/qigemingzihaonan/CodeBuilder.rar
这是一个最基础的例子,仅仅能提供一种思路,然后这个例子也是参考了别人的文章,地址在这里:
http://www.cnblogs.com/lishun1005/p/4069223.html?utm_source=tuicool