做个简单的winfrom应用

用喝啤酒的扎杯泡了一大杯咖啡. 石进的钢琴曲放起来. 今天我不讲三国,说一说C#的简单三层. 做个小一点的winfrom应用程序..记录一下这几晚上的学习成果吧,算是...

数据库用的SqlServer(默默的说一句, 我不会用VS连接MySQL数据库.484傻???)

来吧,已经是中年的骚年.打开VS.

新建一个项目,名称爱叫啥就叫啥,然后右击项目名,添加类库.因为要做三层,所以呢添加个BLL层,再来个DAL层,再来个UI层就完事儿了,就是这么简单就完事了.就这么三个层而已..

C#,Java,PHP,python等等,语言之间都是相互有关联的, 比如说就像女孩,女子,妇女,老太婆,死婆娘之间的关系一样,她们都是女人,就具有女人的天性,没有女人冷冷清清,有了女人鸡犬不宁...大致就这样的吧...

三层呢,就是视图层,业务层,数据层.类似于Android开发中的MVP模式,这么做的好处就是解耦.也便于排查bug,另外相互依赖之间的关系一目了然.就像是女性之间的解耦一样哈.对待女孩要多看看两眼,对待蛮不讲理没文化的老太太就要避而远之.哈哈..

扯了这么多,咱们开始代码吧...

在代码开始之前,还需要在添加两个类库,就是common工具层和Model模型层....这个就相当于化妆品似的, 是对三层的一个修饰吧算是(个人这么理解)

NO.1

首先连接数据库,需要数据库连接字符串..(需要注意的是,这个连接字符串要配置在UI层的App.config里面)



     
        
    
  //数据库连接字符串跟标签
  


这里的Data source指的是数据库服务的名称

接下来在dal层中封装访问数据库的类SqlHelper,需要执行sql语句时直接调用即可,代码如下(需要提前引用System.configuration程序集)

 public static class SqlHelper
    {
        //1,在app.config文件写数据库连接字符串
        //2,读取数据库连接字符串(需要先引用System.Configuration)
       public static String connstr = ConfigurationManager.ConnectionStrings["scc"].ConnectionString;
        //3,insert/delete/update执行数据库的方法
        public static int ExecuteNonQuery(String sql,CommandType cmdtype,params SqlParameter[] pms) {

            using (SqlConnection conn = new SqlConnection(connstr))
            {
                using (SqlCommand cmd = new SqlCommand(sql,conn))
                {   //设置当前的是存储过程还是带参数的SQL语句
                    cmd.CommandType = cmdtype;
                    if (pms!=null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    conn.Open();
                    return cmd.ExecuteNonQuery();
                }
            }
        
        }
        
        //4,执行返回单个返回值的方法
        public static object ExecuteScala(String sql, CommandType cmdType, params SqlParameter[] pms) {

            using (SqlConnection conn = new SqlConnection(connstr))
            {
                using (SqlCommand cmd = new SqlCommand(sql,conn))
                {
                    cmd.CommandType = cmdType;
                    if (pms!=null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    conn.Open();
                    return cmd.ExecuteScalar();
                }
            }
        }

        //5,执行返回多个值得方法
        public static SqlDataReader ExecuteReader(String sql,CommandType cmdType,params SqlParameter[] pms) {
            using (SqlConnection conn = new SqlConnection(connstr))
            {
                using (SqlCommand cmd = new SqlCommand(sql,conn))
                {
                    cmd.CommandType = cmdType;
                    if (pms!=null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    try
                    {
                        conn.Open();
                        return cmd.ExecuteReader(CommandBehavior.CloseConnection);
                    }
                    catch
                    {
                        conn.Close();
                        conn.Dispose();
                        throw;
                    }
                }
            }
        }

        //6,返回数据表的方法
        public static DataTable ExecuteDataTable(String sql,CommandType cmdtype,params SqlParameter [] pms) {
            DataTable dt = new DataTable();
            using (SqlDataAdapter adapter = new SqlDataAdapter(sql,connstr))
            {
                if (pms!=null)
                {
                    adapter.SelectCommand.Parameters.AddRange(pms);
                }
                adapter.Fill(dt);
                return dt;
            }
        }
    }

好了,数据库的增删改查的方法封装好了.接下来呢,先把UI层的要显示的数据UI写一下..如下图

做个简单的winfrom应用_第1张图片
亡者农药.png

目前只写了添加功能,..修改和删除的最后在写...

接下来添加数据
UI层

LoadDataBLL bll = new LoadDataBLL();
dataGridView1.DataSource = bll.getData();

BLL层

public List getData() 
        {
            LoadDataDAL dal = new LoadDataDAL();
            return dal.getData();
        }

DAL层

public class LoadDataDAL
    {
        List lists = new List();
        public List getData() { 
            String sql = "select * from hero";
            DataTable dt = SqlHelper.ExecuteDataTable(sql,CommandType.Text);
            foreach (DataRow row in dt.Rows)
            {
                lists.Add(new HeroModel() { 
                    name = row["name"].ToString(),
                    gender = row["gender"].ToString(),
                    price = Convert.ToInt32(row["price"]),
                    passiveskill = row["passiveskill"].ToString(),
                    oneskill = row["oneskill"].ToString(),
                    twoskill = row["twoskill"].ToString(),
                    threeskill = row["threeskill"].ToString(),
                    role = row["role"].ToString(),
                });
            }
            return lists;
        }

HeroModel就是一个bean类,Javabean类...代码就不贴了..
效果如下:

做个简单的winfrom应用_第2张图片
效果图.png

艾玛...十一点了..不写了.拾掇拾掇碎觉了...明天再继续..晚安(友情推荐晚安神曲---> <只要有你的地方(晚安版)>林俊杰)

你可能感兴趣的:(做个简单的winfrom应用)