zoukankan      html  css  js  c++  java
  • 使用泛型集合取代datatable作为返回值实现面向对象

    开会的时候,师父说。我们在机房重构时,尽量不要用datatable作为返回值。改用泛型集合的方式,这样能够实现真正的面向对象。

    通过查资料和同学交流,把这个问题给攻克了。

    对于泛型集合。我也有了一些认识。

    一、对泛型集合的认识

    1.存在于System.Collection,Generic的命名空间中,在用的时候。须要引用

    2.泛型是具有占位符(类型參数)的类,结构,接口和方法。就是说,在泛型集合中增加的数据必须符合指定的类型<T>,否则编译时就会报错。

    以上为设计模式培训实习生的内容。

    那泛型集合与datatable相比,究竟有什么长处呢?

    1.datatable在使用时,须要了解数据库的结构,比方。我们想要获得某个字段的值,就必须知道它在数据表中的第几个字段。datatable.rows(1).Item(2)等。可是。使用泛型集合则不用,比方想要获得用户的username,则能够直接写mylist.Item(0).UserName.这里Item指你要获得的第几个实体

    2.假设有成千上万条数据,datatable会出现意想不到的麻烦。但是,利用泛型则能够使用循环语句。自己主动获得数据。

    for i=0 to mylist.count-1 ,极大地方便了编程人员

    3.泛型符合面向对象的思想 。

    泛型集合中将每一条数据当成了一个实体来对待,而每一个字段则当成该实体的不同的属性。

    所以,我们通常使用泛型集合的方式来作为返回值,更加方便。


    二、那么。应用在实际编程中,该怎样应用它呢?在这里谨表自己做一下笔记。

    这里,仅仅是将我们原来的返回值datatable类型进行转换成为泛型集合类,因为每次转换的步骤是一样的。

    因为非常多时候,我们常常会在显示层,来显示数据,所以同一时候。我们在显示层也会须要用到返回的实体,也就是说,我们在U,B。D层都可能会用到返回值。

    所以。我们将转换的方法抽象出一个类来放到实体层(可依据自己习惯建立)。以供各层随时调用。


    Imports System.Collections.Generic
    Imports System.Reflection
    Public Class ConvertHelper
        'of T as new 用来对T进行约束,必须包括有空的无參构造函数
        Public Shared Function ConvertToList(Of T As {New})(ByVal dt As DataTable) As List(Of T)
            '定义一个泛型集合,用于存放返回集合
            Dim ds As New List(Of T)
    
            '定义一个变量。来得到返回集合中实体类型
            Dim type As Type = GetType(T)
    
            '定义一个暂时变量。用来存放datatable中的每一个实体的属性
            Dim proName As String = String.Empty '初始调用时,为空字符串
    
            '定义行实体
            Dim dr As DataRow
            '遍历DataTable中的全部数据行,即全部记录
            For Each dr In dt.Rows
                '实例化一个泛型集合中的实体,即代表一条记录
                Dim record As New T
                '定义一个属性信息的集合
                'propertyInfo探索屬性 (Property) 的屬性 (Attribute),並提供屬性中繼資料 (Metadata) 的存取
                Dim propertys() As PropertyInfo = record.GetType().GetProperties() '获取实体的全部属性
                '遍历全部属性
                Dim pro As PropertyInfo
                For Each pro In propertys
                    '每循环一次将属性的名称赋值给暂时变量proName
                    proName = pro.Name
                    '利用暂时遍历中的属性名称来检查该记录中是否包括此列
                    If dt.Columns.Contains(proName) Then
                        '包括此列的同一时候,必须保证该列可写
                        If pro.CanWrite = False Then Continue For '直接跳出,继续执行循环
                        '取值
                        Dim value As Object = dr(proName) '保存列名的值
                        If (value.ToString <> DBNull.Value.ToString()) Then '假设非空。则赋给对象的属性   
                            '用索引化属性的可选索引值设置指定对象的该属性值
    
                            pro.SetValue(record, value, Nothing)    '在执行期间,通过反射,动态的訪问一个对象的属性
                        End If
                    End If
    
                Next
                ds.Add(record)
            Next
            Return ds '返回实体的泛型集合
    
        End Function
    End Class

    在上述代码中,还需注意一个方法:setvalue,这种方法存在于System.Reflection这个命名空间中,所以,须要提前引用。

    在创建该转换函数时,须要对类型<T>进行约束。假设client代码尝试使用某个约束所不同意的类假设client代码尝试使用某个约束所不同意的类型来实例化类,则会产生编译时错误。这里通过一个空的构造函数New来进行约束。

    三、返回值

    作为我们声明方法的一类返回值,返回类型能够为一个单独的实体,即仅仅含有一条记录。或者返回一个含有多条记录的集合(list)

    比如:as T

    或者 as list(of T)

    四、与控件连接显示数据

    在与DataGridView控件进行连接显示数据时,我们仅仅要将我们原来的数据源改为声明的列表就可以,同一时候注意应将自己主动载入列属性(AutoGenerateColumns)改为TRUE,否则控件中不能显示数据。

    有一个疑问:原来使用datatable时。在控件第一行的名称能够通过D层查询语句使用别名的方式,直接显示在控件中,比如sql="select UserName as username where ID=@ID",但是将数据源设为列表时,便不能显示了。并且也不能载入数据。攻克了非常长时间,还是没能找到一个合理的原因。最后仅仅好在U层直接编辑HeaderText了。


    以上是学习到的泛型集合的相关知识。通过机房重构,运用三层,结合设计模式,发现能够学习到非常多新的知识,增长非常多见识,慢慢的认为编程还是非常有意思的。

    继续努力!

  • 相关阅读:
    saxbuilder用法
    【转】开篇python--明白python文件如何组织,理解建立源文件
    [转]linux awk命令详解
    sed 指定行范围匹配(转)
    MySQL Error Code文档手册---摘自MySQL官方网站
    java文件读写操作大全
    详解coredump
    Java中Map根据键值(key)或者值(value)进行排序实现
    java如何对map进行排序详解(map集合的使用)
    遍历Map的四种方法
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/6707215.html
Copyright © 2011-2022 走看看