zoukankan      html  css  js  c++  java
  • 我已经写了DAL层的代码生成器

    (1)创建您自己的解决方案 文件夹结构如以下:


    (2)编写代码:

    (要使用数据库 建议创建随意数据库就可以)

    创建配置文件App.config代码例如以下:

    <?xml version="1.0"?>
    <configuration>
      <connectionStrings>
        <add name="connstr" connectionString="Data Source=.; Initial Catalog=HRMSYSDB;User ID=hrmsa;Password=你的数据库密码"/>
      </connectionStrings>
      <appSettings>
        <add key="passwordSalt" value="love?P3@9"/>
        <add key="aaa" value="333"/>
      </appSettings>
      
    </configuration>
    
    MainWindow.xaml代码例如以下:(在MainWindow.xaml下把Grid里边的代码换一下就好了)

    <Grid>
            <TextBox Height="23" HorizontalAlignment="Left" Margin="16,7,0,0" Name="txtConnStr" VerticalAlignment="Top" Width="542" />
            <Button Content="连接" Height="23" HorizontalAlignment="Left" Margin="564,7,0,0" Name="btnConnect" VerticalAlignment="Top" Width="41" Click="btnConnect_Click" />
            <ComboBox Height="23" HorizontalAlignment="Left" Margin="16,36,0,0" Name="cmbTables" VerticalAlignment="Top" Width="210" IsEnabled="False" />
            <Button Content="生成代码" Height="23" HorizontalAlignment="Left" Margin="244,36,0,0" Name="btnGenerateCode" VerticalAlignment="Top" Width="75" IsEnabled="False" Click="btnGenerateCode_Click" />
            <TextBox TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Height="483" HorizontalAlignment="Left" Margin="16,66,0,0" Name="txtModelCode" VerticalAlignment="Top" Width="342" IsReadOnly="True" />
            <TextBox TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Height="483" HorizontalAlignment="Left" Margin="372,66,0,0" Name="txtDALCode" VerticalAlignment="Top" Width="494" IsReadOnly="True" />
        </Grid>

    MainWindow.xaml.cs代码例如以下:

    namespace MyCodeGen //这里要把命名空间改成自己的 也就是自己生成的   仅仅需粘贴<span style="font-family: Arial, Helvetica, sans-serif;">public partial class MainWindow : Window{  下边的内容就可以</span>
    
    {
        /// <summary>
        /// MainWindow.xaml 的交互逻辑
        /// </summary>
        public partial class MainWindow : Window
        {
            public MainWindow()
            {
                InitializeComponent();
            }
    
            private DataTable ExecuteDataTable(string sql)
            {
                using (SqlConnection conn = new SqlConnection(txtConnStr.Text))
                {
                    conn.Open();
                    using (SqlCommand cmd = conn.CreateCommand())
                    {
                        //仅仅获得表的架构信息(列信息)
                        cmd.CommandText = sql;
                        DataSet ds = new DataSet();
                        SqlDataAdapter adapter = new SqlDataAdapter(cmd);
                        adapter.FillSchema(ds, SchemaType.Source);//获得表信息必须要写
                        adapter.Fill(ds);
                        return ds.Tables[0];
                    }
                }
            }
    
            private void btnConnect_Click(object sender, RoutedEventArgs e)
            {
                DataTable table;
                try
                {
                    table = ExecuteDataTable(@"SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES 
                            WHERE TABLE_TYPE = 'BASE TABLE'");
                }
                catch (SqlException sqlex)
                {
                    MessageBox.Show("连接数据库出错!错误消息:" + sqlex.Message);
                    return;
                }
                string[] tables = new string[table.Rows.Count];
                for (int i = 0; i < table.Rows.Count; i++)
                {
                    DataRow row = table.Rows[i];
                    tables[i] = (string)row["TABLE_NAME"];
                }
                cmbTables.ItemsSource = tables;
                cmbTables.IsEnabled = true;
                btnGenerateCode.IsEnabled = true;
    
                //把连接字符串记录到文件里。避免用户每次都须要输入连接字符串
    
                //将连接字符串保存起来
                string configFile = GetConfigFilePath();
                File.WriteAllText(configFile, txtConnStr.Text);
    
                //除非真的有捕获异常的须要,否则不要try...catch
            }
    
            //为例避免每次都输入链接数据库字符串 将保存的代码封装到函数中
            private static string GetConfigFilePath()
            {
                string currenctDir = AppDomain.CurrentDomain.BaseDirectory;
                string configFile = System.IO.Path.Combine(currenctDir, "connstr.txt");
                return configFile;
            }
    
            private void Window_Loaded(object sender, RoutedEventArgs e)
            {
                //在每次载入的时候都要载入  保存在目录内的 连接字符串
                string configFile = GetConfigFilePath();
                txtConnStr.Text = File.ReadAllText(configFile);
            }
    
            private void btnGenerateCode_Click(object sender, RoutedEventArgs e)
            {
                string tablename = (string)cmbTables.SelectedItem;
                if (tablename == null)
                {
                    MessageBox.Show("请选择要生成的表");
                    return;
                }
                CreateModelCode(tablename);
                CreateDALCode(tablename);
            }
    
            private void CreateModelCode(string tablename)
            {
    
                DataTable table = ExecuteDataTable("select top 0 * from "
                    + tablename);
                //在大量的字符串拼接的时候使用stringbuilder()
                StringBuilder sb = new StringBuilder();
                sb.Append("public class ").AppendLine(tablename).AppendLine("{");
                foreach (DataColumn column in table.Columns)
                {
                    string columnDataType = GetDataTypeName(column); //推断类型是否可空
                    sb.Append("    ").Append("public ").Append(columnDataType).Append(" ")
                        .Append(column.ColumnName).AppendLine("{get;set;}");
                }
                sb.AppendLine("}");
                txtModelCode.Text = sb.ToString();
            }
    
            //进行可空类型的处理
            private static string GetDataTypeName(DataColumn column)
            {
                //假设列同意为null。而且列在C#中的类型是不可为空的(值类型ValueType)
                if (column.AllowDBNull && column.DataType.IsValueType)
                {
                    return column.DataType + "?";
                }
                else
                {
                    return column.DataType.ToString();
                }
            }
    
    
            //下边是生成DALcode部分
            private void CreateDALCode(string tablename)
            {
                DataTable table = ExecuteDataTable("select top 0 * from "
                    + tablename);
                StringBuilder sb = new StringBuilder();
                sb.Append("public class ").Append(tablename).AppendLine("DAL").AppendLine("{");
    
                //tomodel開始
                sb.Append("    ").Append("private ").Append(tablename)
                    .AppendLine(" ToModel(DataRow row)").Append("    ").AppendLine("{");
                sb.Append("        ").Append(tablename).AppendLine(" model = new " + tablename + "();");
                foreach (DataColumn column in table.Columns)
                {
                    //不管列是否同意为空,都进行推断DbNull的处理(省事)
                    //model.Id = (Guid)SqlHelper.FromDbValue(row["Id"]);
                    sb.Append("        ").Append("model.").Append(column.ColumnName).Append("=(")
                        .Append(GetDataTypeName(column)).Append(")SqlHelper.FromDbValue(row["")
                       .Append(column.ColumnName).AppendLine(""]);");
                }
                sb.Append("        ").AppendLine("return model;");
                sb.AppendLine("}");
                //tomodel的结束
    
                //listall開始
                sb.Append("public IEnumerable<").Append(table)
                    .AppendLine("> ListAll()").AppendLine("{");
                sb.Append("    ").Append("List<").Append(tablename).Append("> list=new List<")
                    .Append(tablename).AppendLine(">();");
                sb.Append("DataTable dt = SqlHelper.ExecuteDataTable("")
                    .Append("select * from " + tablename).AppendLine("");");
                sb.AppendLine("foreach (DataRow row in dt.Rows)");
                sb.Append(tablename).AppendLine(" model=ToModel(row);");
                sb.AppendLine("list.Add(model);}");
    
                sb.AppendLine("}");
    
    
                //生成器要求列名必须是Id,类型必须是Guid
    
                //Insert開始
                //public void Insert(Operator op)
                sb.Append("public void Insert(")
                    .Append(tablename).AppendLine(" model){");
                //SqlHelper.ExecuteNonQuery(@"insert into T_Operator(
                sb.Append("SqlHelper.ExecuteNonQuery(@"")
                    .Append("insert into ").Append(tablename).AppendLine("(");
                string[] colNames = GetColumnNames(table);
                sb.AppendLine(string.Join(",", colNames));
                string[] colParamNames = GetParamColumnNames(table);
                sb.Append("values(").AppendLine(string.Join(",", colParamNames));
                sb.AppendLine("}");
                //Insert结束
    
                sb.AppendLine("}");
                txtDALCode.Text = sb.ToString();
            }
    
            //以数组形式返回列名
            private static string[] GetColumnNames(DataTable table)
            {
                string[] colnames = new string[table.Columns.Count];
                for (int i = 0; i < table.Columns.Count; i++)
                {
                    DataColumn dataCol = table.Columns[i];
                    colnames[i] = dataCol.ColumnName;
                }
                return colnames;
            }
    
            //以数组形式返回@列名
            private static string[] GetParamColumnNames(DataTable table)
            {
                string[] colnames = new string[table.Columns.Count];
                for (int i = 0; i < table.Columns.Count; i++)
                {
                    DataColumn dataCol = table.Columns[i];
                    colnames[i] = "@" + dataCol.ColumnName;
                }
                return colnames;
            }
        }
    }
    

    SqlHelper.cs代码例如以下:(命名空间里边的代码)

    namespace MyCodeGen
    {
        static class SqlHelper
        {
            //app.config文件的继承:
    
            public static readonly string connstr =
                ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;
            //别忘了加入引用 System.configuration 然后在解析到  步骤:右键点击引用--加入引用--.NET--找到System.configuration 确定就可以
    
            public static int ExecuteNonQuery(string sql,
                params SqlParameter[] parameters)
            {
                using (SqlConnection conn = new SqlConnection(connstr))
                {
                    conn.Open();
                    using (SqlCommand cmd = conn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
                        return cmd.ExecuteNonQuery();
                    }
                }
            }
    
            public static object ExecuteScalar(string sql,
                params SqlParameter[] parameters)
            {
                using (SqlConnection conn = new SqlConnection(connstr))
                {
                    conn.Open();
                    using (SqlCommand cmd = conn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
                        return cmd.ExecuteScalar();
                    }
                }
            }
    
            public static DataTable ExecuteDataTable(string sql,
                params SqlParameter[] parameters)
            {
                using (SqlConnection conn = new SqlConnection(connstr))
                {
                    conn.Open();
                    using (SqlCommand cmd = conn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
    
                        DataSet dataset = new DataSet();
                        SqlDataAdapter adapter = new SqlDataAdapter(cmd);
                        adapter.Fill(dataset);
                        return dataset.Tables[0];
                    }
                }
            }
    
            public static object FromDbValue(object value)
            {
                if (value == DBNull.Value)
                {
                    return null;
                }
                else
                {
                    return value;
                }
            }
    
            public static object ToDbValue(object value)
            {
                if (value == null)
                {
                    return DBNull.Value;
                }
                else
                {
                    return value;
                }
            }
        }
    }
    



    好了 所有代码都好了!点击执行效果例如以下:



    另外须要完整项目的请点击:

    http://download.csdn.net/detail/u010870518/7837691


    假设导入数据库mdf不熟悉的请參考:

    http://blog.csdn.net/xlgen157387/article/details/38844315


    版权声明:本文博主原创文章,博客,未经同意不得转载。

  • 相关阅读:
    「四步接入」开启秀场直播,揭秘七牛云互动直播解决方案
    【直播预告】揭秘互动直播,技术咖携手美女主播解读直播背后那点事儿
    初识k8s(基础概念加历史了解)(一)
    Linux lsof命令的使用示例
    Linux netstat:查看网络状态
    Linux uname命令:查看系统和内核相关信息
    系统环境变量PATH的设置与查看,以Mac为例
    Shell echo命令
    Linux which命令
    【转译】每个Python开发者都应该掌握的8种数据结构
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/4850236.html
Copyright © 2011-2022 走看看