美文网首页
做个简单的winfrom应用

做个简单的winfrom应用

作者: 那个唐僧 | 来源:发表于2017-09-06 22:41 被阅读104次

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

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

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

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

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

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

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

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

NO.1

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

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
<connectionStrings>  //数据库连接字符串跟标签
  <add name="scc" //添加的连接字符串的key和value connectionString="Data source=.;initial Catalog=test;Integrated Security=True"/>
</connectionStrings>
</configuration>

这里的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写一下..如下图

亡者农药.png

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

接下来添加数据
UI层

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

BLL层

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

DAL层

public class LoadDataDAL
    {
        List<HeroModel> lists = new List<HeroModel>();
        public List<HeroModel> 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类...代码就不贴了..
效果如下:

效果图.png

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

相关文章

  • 做个简单的winfrom应用

    用喝啤酒的扎杯泡了一大杯咖啡. 石进的钢琴曲放起来. 今天我不讲三国,说一说C#的简单三层. 做个小一点的winf...

  • Winform绘制圆角按钮

    最近做Winfrom项目,Winfrom不同于WPF,界面效果没有WPF那么好做,圆角按钮只能靠出背景图,但是总是...

  • 01.Python-GUI编程小试—在线查询ip归属地

    引言 19年那会,朋友想做个桌面级应用,就简单学习了下Python-GUI编程,学习之初简单做了个小应用,主要使用...

  • AVFoundation的的视频采集使用

    相机相关应用一般会用到AVFoundation. 这里简单做个整理。 AVFoundation是基于session...

  • Elasticsearch实战总结

    上手elasticsearch有段时间了,主要以应用为主,未做深入的研究,下面就简单的日常作个简单的总结,做个记录...

  • Winfrom程序组件

    菜单栏和工具栏 1、MenuStrip:顶部菜单,可右键点击插入标准项 2、ContextMenuStrip:右键...

  • 使用WinFrom控件

    编辑工程文件 在UseWPF下 加上 true

  • 《做个俗人,不谈亏欠》

    【不二微岩】《做个俗人,不谈亏欠》 做个俗人, 快乐简单, 发型简单, 衣着简单, 用餐简单, 简单简单。 俗人即...

  • 《做个俗人,不谈亏欠》

    【不二微岩】《做个俗人,不谈亏欠》 做个俗人, 快乐简单, 发型简单, 衣着简单, 用餐简单, 简单简单。 俗人即...

  • C# 特性

    泛型 无 lambda表达式 无 匿名函数 无 委托 winfrom界面委托 在对控件进行操作的时候,可以通过判断...

网友评论

      本文标题:做个简单的winfrom应用

      本文链接:https://www.haomeiwen.com/subject/bsovjxtx.html