今天,我首先在之前所做的人员管理系统的基础上,利用数据访问类进行了所有人员信息的查询。

  主程序代码:

  1. List<Users> Ulist = new UsersData().Select();
  2.  
  3. if (Ulist.Count > )//判断是否包含语句
  4. {
  5. foreach (Users u1 in Ulist)//遍历
  6. {
  7. Console.WriteLine(u1.UserName + " " + u1.PassWord + " " + u1.NickName + " " + u1.Sex + " " + u1.Birthday + " " + u1.Nation);
  8. }
  9.  
  10. }

  UsersData数据访问类中的代码:

  1.      public List<Users> Select()
  2. {
  3. List<Users> list=new List<Users>();
  4. cmd.CommandText="select * from Users";
  5.  
  6. conn.Open();
  7. SqlDataReader dr=cmd.ExecuteReader();
  8. if(dr.HasRows)//判断是否包含数据
  9. {
  10. while(dr.Read())
  11. {
  12. Users u=new Users();
  13. u.UserName=dr["UserName"].ToString();
  14. u.PassWord=dr["PassWord"].ToString();
  15. u.NickName=dr["NickName"].ToString();
  16. u.Sex = Convert.ToBoolean(dr["Sex"]);
  17. u.Birthday=Convert.ToDateTime(dr["Birthday"]);
  18. u.Nation=dr["Nation"].ToString();
  19.  
  20. list.Add(u);
  21. }
  22. }
  23. conn.Close();
  24.  
  25. return list;
  26. }

  之后,我学习了属性扩展的内容。

  属性扩展就是将程序中所显示的代码显示为普通用户也可以看懂的字符。这就需要我们在实体类中,给成员变量再添加一个新的属性,该属性只用写上读取,即get{},在主程序中调用这个属性,如:

  1.     private DateTime _Birthday;
  2. /// <summary>
  3. /// 生日
  4. /// </summary>
  5. public DateTime Birthday
  6. {
  7. get { return _Birthday; }
  8. set { _Birthday = value; }
  9. }
  10. public string BirthdayStr
  11. {
  12. get { return _Birthday.ToString("yyyy年MM月dd日");}
  13. }

  若所要更改显示的内容在不同的表中,如:人员管理系统中民族代码改为民族名称(民族代码Nation在人员信息表Users中,而民族代码NationCode和民族名称NationName在民族信息表Nation中),则实体类Users中的代码为:

  1.     private string _Nation;
  2.  
  3. /// <summary>
  4. /// 民族
  5. /// </summary>
  6. public string Nation
  7. {
  8. get { return _Nation; }
  9. set { _Nation = value; }
  10. }
  11. public string NationName
  12. {
  13. get
  14. {
  15. NationData Ndata = new NationData();
  16. string end = Ndata.select(_Nation);
  17. return end;
  18. }
  19. }

  而数据访问类NationData中的代码为:

  1.   public class NationData
  2. {
  3. SqlConnection conn = null;
  4. SqlCommand cmd = null;
  5.  
  6. public NationData()
  7. {
  8. conn = new SqlConnection("server=.;database=Data0720;user=sa;pwd=123;");
  9. cmd = conn.CreateCommand();
  10. }
  11.  
  12. public string select(string code)
  13. {
  14. string end = "<无>";
  15.  
  16. cmd.CommandText = "select * from Nation where NationCode=@a";
  17. cmd.Parameters.Clear();
  18. cmd.Parameters.Add("@a",code);
  19.  
  20. conn.Open();
  21. SqlDataReader dr = cmd.ExecuteReader();
  22. if(dr.HasRows)
  23. {
  24. dr.Read();
  25. end=dr["NationName"].ToString();
  26. }
  27.  
  28. conn.Close();
  29. return end;
  30. }
  31.  
  32. }

  今天,我还了解到了,通过卡断点,可以很好的处理程序中未知的BUG,并且可以很准确的找到BUG的位置。在写函数时,我们把每个函数的功能写的越少,越抽象,那么这个函数被应用的范围就会越广。

ADO.NET 数据访问类查询、属性扩展的更多相关文章

  1. ADO.NET(完整修改和查询、实体类,数据访问类)

    一.完整修改和查询 在编写c#语句时需考虑到用户体验,例如在编写修改语句时,需要考虑到输入的内容在数据库中是否能够找到. 中间变量运用. 1.先查 2.执行操作 完整修改语句: bool has = ...

  2. 9_13学习完整修改和查询&&实体类,数据访问类

    完整修改和查询:中间变量运用. 1.先查 2.执行操作 ---------------------------------------------------- namespace ADO.NET_小 ...

  3. ADO.NET(一) 空间 ADO.NET结构 命名空间(车延禄) System.Data—— 所有的一般数据访问类 S(转载)

    ADO.NET(一) 空间   ADO.NET结构 命名空间(车延禄)System.Data—— 所有的一般数据访问类System.Data.Common—— 各个数据提供程序共享(或重写)的类Sys ...

  4. ADO,NET 实体类 和 数据访问类

    啥也不说,看代码. --SQl中 --建立ren的数据库,插入一条信息 create database ren go use ren go create table xinxi ( code ) pr ...

  5. ADO.NET 【实体类】【数据访问类】

    认识分层结构,分层式结构是最常见,也是最重要的一种结构. 三层架构(3-tier architecture) 界面层(User Interface layer) 主要对用户的请求接受,以及数据的返回, ...

  6. ado.net 实体类_数据访问类

    实体类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...

  7. ADO.net 实体类 、数据访问类

    程序分三层:界面层.业务逻辑层.数据访问层 比较规范的写程序方法,要把业务逻辑层和数据访问层分开,此时需要创建实体类和数据访问类 实体类: 例 using System; using System.C ...

  8. 【2017-04-20】Ado.Net与面向对象结合架构中的数据访问层(实体类,数据访问类)

    开发项目三层架构:界面层.业务逻辑层.数据访问层 今天学习一下数据访问层,分为实体类和数据访问类 所有的类放在App_Code这个文件夹下边.养成一个好的习惯. 一.实体类 数据库中的表映射为一个类, ...

  9. C#-ade.net-实体类、数据访问类

    实体类.数据访问类 是由封装演变而来,使对数据的访问更便捷,使用时只需要调用即可,无需再次编写代码 实体类是按照数据库表的结构封装起来的一个类 首先,新建文件夹 App_Code ,用于存放数据库类等 ...

随机推荐

  1. PHP的ip2long和long2ip函数的实现原理

    最近要做个十进制数字的可逆转换做邀请码,一直没搞清楚怎么弄的,实在太复杂了,今天弄IP时想到这个可以进行转换,于是研究了下原理: 主要是自己整理了下: $ip = '12.34.56.78'; $ip ...

  2. Android使用Eclipse遇到"java.lang.ClassNotFoundException"

    最近遇到个Android Jar的问题,找了几天才找到root cause. 在此记录下. 我们的Android项目需要使用一个供应商的Jar. 我们使用的开发环境为:Eclipse + ADT插件( ...

  3. react 学习与使用记录

    相关技术:webpack+react+react-router+redux+immutable 郭永峰react学习指南 1.git bash--windows命令行工具 --教程 下载地址 2. i ...

  4. [UWP小白日记-3]记账项目-1

    学了一段时间的UWP,来个项目试试手. 本来是想边做边学MVVMLight的结果感觉MVVM对于萌新来说太高难,以后再把这个项目改造成MVVMLight框架的项目. 下面进入正题. 中间那快空白打算放 ...

  5. 使用rsync无密码传输

    众多数据库服务器的管理过程中,在不同服务器间的文件传输是免不了的.您可以使用scp命令或FTP方法完成文件的发送和接收,这篇文章我将给大家介绍另外一种方法,这就是rsync命令.rsync是文件传输程 ...

  6. C# 压缩打包文件下载

    C# 压缩打包文件下载 public class MyNameTransfom : ICSharpCode.SharpZipLib.Core.INameTransform { #region INam ...

  7. BestCoder 百度之星2016

    20160523 百度之星初赛第一场 1001 All X Problem Description F(x, m)F(x,m) 代表一个全是由数字xx组成的mm位数字.请计算,以下式子是否成立: F( ...

  8. 注册表对比工具(Regshot) V2.0.1 中文绿色版

    软件名称: 注册表对比工具(Regshot)软件语言: 简体中文授权方式: 免费软件运行环境: Win7 / Vista / WinXP软件大小: 263KB图片预览: 软件简介:Regshot 是一 ...

  9. 扔鸡蛋问题详解(Egg Dropping Puzzle)

    http://blog.csdn.net/joylnwang/article/details/6769160 经典的动态规划问题,题设是这样的:如果你有2颗鸡蛋,和一栋36层高的楼,现在你想知道在哪一 ...

  10. 2015 Syrian Private Universities Collegiate Programming Contest 题解

    题目在这里>_< 发现这场比赛在网上没有完整的题解,甚至连题目代码都没人贴出来(大概是因为题目太水了吧...).所以宝宝就来写个题解,也就当作成长记录了233333 A. Window 题 ...