0

我得到了一个库,其中包含通用数据对象、项目、表、行和字段。在我的程序中,我有一个名为 Building 的项目,它的表 1 包含“单位”,表 1 的字段 1 是“单位名称”。所以我所做的是...

Public Class Unit
  Private myRow As Row
  Public Sub New(ByRef R as Row)
    myRow = Row
  End Sub
  Public Function Unitname() as String
    Return myRow.Fields(1)
  End Function
  ... etc ...
End Class

这看起来还不错吧?但是我没有加载单元对象,我有行。所以那我还得再上一堂课……

Public Class Building
  Private myProj as Project
...
  Public Function Units() As List(Of Unit)
    Dim ans as New List(Of Unit)
    For Each R In myProj.Tables(1).Rows
      ans.Add(new Unit(R))
    Next
    Return ans
    ' or I could use myProj.Tables(1).Rows.ConvertTo(Of Unit)
 End Function
 ...etc...

当然,我必须创建建筑物列表,这样我才能访问单元列表,以及其他数十个列表和访问器,变成数千行代码,其唯一目的是制作一组指向的对象其他。

它有效,而且我知道运输是一项功能。但我真正想做的是制作一个看起来像......

Public Class Unit
  Inherits Row
  ...
End Class

然后我会将 List(Of Row) “反向转换”为 List(Of Unit)。这不仅会消除大量代码,还会消除悬空指针,大量减少内存,并消除可能需要一些时间的设置集。理论上可能,除了代码没有区别,但我没有看到在 VB.Net 中做到这一点的方法。

在 Obj-C 中,这被称为 swizzling(和/或扩展),我认为 Java 也有类似的概念。我怀疑 ADO.Net 必须做这样的事情?我是否缺少某种“将其包装在内”的功能?

4

2 回答 2

0

如果您不想使用 DataSet,可以尝试共享转换器功能:

  Class unit
    Inherits row

    Public Property UnitName() As String
      Get
        Return fields(1)
      End Get
      Set(ByVal value As String)
        fields(1) = value
      End Set
    End Property

    Shared Function UnitToRow(u As unit) As row
      Return DirectCast(u, row)
    End Function

    Shared Function RowToUnit(r As row) As unit
      Dim u As New unit
      u.fields = r.fields
      Return u
    End Function

  End Class

  Sub usage()
    Dim lstR As New List(Of row) '<--- source data

    Dim lstU As List(Of unit) = lstR.ConvertAll(New Converter(Of row, unit)(AddressOf unit.RowToUnit))
    MsgBox(lstU(0).UnitName)

    lstU(0).UnitName = "xxx"

    Dim lstR2 As List(Of row) = lstU.ConvertAll(New Converter(Of unit, row)(AddressOf unit.UnitToRow))
    MsgBox(lstR2(0).fields(1))

  End Sub
于 2015-01-19T23:38:37.700 回答
0

节省大量时间并使用 DataSet。对于数据库应用程序,面向对象的编程并不能很好地工作。数据集只能在内存中,不需要数据库引擎。

Dim dsProject As New DataSet("Project")
Dim dtUnits As New DataTable("Units")
dtUnits.Columns.Add("Unitname", GetType(String))
dtUnits.Columns.Add("Address", GetType(String))
dsProject.Tables.Add(dtUnits)
dtUnits.Rows.Add("Unit 1", "1 Test Street")
dtUnits.Rows.Add("Unit 2", "2 Sample Avenue")
dtUnits.Rows.Add("Unit 3", "3a Demo Road")

Dim drMatch() As DataRow = dtUnits.Select("Unitname='Unit 1'")
If drMatch.GetUpperBound(0) >= 0 Then
  MsgBox(drMatch(0).Item("Address"))
Else
  MsgBox("No matching record")
End If
于 2015-01-15T00:45:50.460 回答