做个简单的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里面)

<?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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容