allorders.vb
来自「Mastering VBNet Include Source Code」· VB 代码 · 共 1,416 行 · 第 1/4 页
VB
1,416 行
Me(Me.tableCustomers.CustomerIDColumn) = value
End Set
End Property
Public Property CompanyName As String
Get
Return CType(Me(Me.tableCustomers.CompanyNameColumn),String)
End Get
Set
Me(Me.tableCustomers.CompanyNameColumn) = value
End Set
End Property
Public Property ContactName As String
Get
Try
Return CType(Me(Me.tableCustomers.ContactNameColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.ContactNameColumn) = value
End Set
End Property
Public Property ContactTitle As String
Get
Try
Return CType(Me(Me.tableCustomers.ContactTitleColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.ContactTitleColumn) = value
End Set
End Property
Public Property Address As String
Get
Try
Return CType(Me(Me.tableCustomers.AddressColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.AddressColumn) = value
End Set
End Property
Public Property City As String
Get
Try
Return CType(Me(Me.tableCustomers.CityColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.CityColumn) = value
End Set
End Property
Public Property _Region As String
Get
Try
Return CType(Me(Me.tableCustomers._RegionColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers._RegionColumn) = value
End Set
End Property
Public Property PostalCode As String
Get
Try
Return CType(Me(Me.tableCustomers.PostalCodeColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.PostalCodeColumn) = value
End Set
End Property
Public Property Country As String
Get
Try
Return CType(Me(Me.tableCustomers.CountryColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.CountryColumn) = value
End Set
End Property
Public Property Phone As String
Get
Try
Return CType(Me(Me.tableCustomers.PhoneColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.PhoneColumn) = value
End Set
End Property
Public Property Fax As String
Get
Try
Return CType(Me(Me.tableCustomers.FaxColumn),String)
Catch e As InvalidCastException
Throw New StrongTypingException("Cannot get value because it is DBNull.", e)
End Try
End Get
Set
Me(Me.tableCustomers.FaxColumn) = value
End Set
End Property
Public Function IsContactNameNull() As Boolean
Return Me.IsNull(Me.tableCustomers.ContactNameColumn)
End Function
Public Sub SetContactNameNull()
Me(Me.tableCustomers.ContactNameColumn) = System.Convert.DBNull
End Sub
Public Function IsContactTitleNull() As Boolean
Return Me.IsNull(Me.tableCustomers.ContactTitleColumn)
End Function
Public Sub SetContactTitleNull()
Me(Me.tableCustomers.ContactTitleColumn) = System.Convert.DBNull
End Sub
Public Function IsAddressNull() As Boolean
Return Me.IsNull(Me.tableCustomers.AddressColumn)
End Function
Public Sub SetAddressNull()
Me(Me.tableCustomers.AddressColumn) = System.Convert.DBNull
End Sub
Public Function IsCityNull() As Boolean
Return Me.IsNull(Me.tableCustomers.CityColumn)
End Function
Public Sub SetCityNull()
Me(Me.tableCustomers.CityColumn) = System.Convert.DBNull
End Sub
Public Function Is_RegionNull() As Boolean
Return Me.IsNull(Me.tableCustomers._RegionColumn)
End Function
Public Sub Set_RegionNull()
Me(Me.tableCustomers._RegionColumn) = System.Convert.DBNull
End Sub
Public Function IsPostalCodeNull() As Boolean
Return Me.IsNull(Me.tableCustomers.PostalCodeColumn)
End Function
Public Sub SetPostalCodeNull()
Me(Me.tableCustomers.PostalCodeColumn) = System.Convert.DBNull
End Sub
Public Function IsCountryNull() As Boolean
Return Me.IsNull(Me.tableCustomers.CountryColumn)
End Function
Public Sub SetCountryNull()
Me(Me.tableCustomers.CountryColumn) = System.Convert.DBNull
End Sub
Public Function IsPhoneNull() As Boolean
Return Me.IsNull(Me.tableCustomers.PhoneColumn)
End Function
Public Sub SetPhoneNull()
Me(Me.tableCustomers.PhoneColumn) = System.Convert.DBNull
End Sub
Public Function IsFaxNull() As Boolean
Return Me.IsNull(Me.tableCustomers.FaxColumn)
End Function
Public Sub SetFaxNull()
Me(Me.tableCustomers.FaxColumn) = System.Convert.DBNull
End Sub
Public Function GetOrdersRows() As OrdersRow()
Return CType(Me.GetChildRows(Me.Table.ChildRelations("CustomersOrders")),OrdersRow())
End Function
End Class
Public Class CustomersRowChangeEvent
Inherits EventArgs
Private eventRow As CustomersRow
Private eventAction As System.Data.DataRowAction
Public Sub New(ByVal row As CustomersRow, ByVal action As DataRowAction)
MyBase.New
Me.eventRow = row
Me.eventAction = action
End Sub
Public ReadOnly Property Row As CustomersRow
Get
Return Me.eventRow
End Get
End Property
Public ReadOnly Property Action As DataRowAction
Get
Return Me.eventAction
End Get
End Property
End Class
Public Class Order_DetailsDataTable
Inherits DataTable
Implements System.Collections.IEnumerable
Private columnOrderID As DataColumn
Private columnProductID As DataColumn
Private columnUnitPrice As DataColumn
Private columnQuantity As DataColumn
Private columnDiscount As DataColumn
Friend Sub New()
MyBase.New("Order Details")
Me.InitClass
End Sub
<System.ComponentModel.Browsable(false)> _
Public ReadOnly Property Count As Integer
Get
Return Me.Rows.Count
End Get
End Property
Friend ReadOnly Property OrderIDColumn As DataColumn
Get
Return Me.columnOrderID
End Get
End Property
Friend ReadOnly Property ProductIDColumn As DataColumn
Get
Return Me.columnProductID
End Get
End Property
Friend ReadOnly Property UnitPriceColumn As DataColumn
Get
Return Me.columnUnitPrice
End Get
End Property
Friend ReadOnly Property QuantityColumn As DataColumn
Get
Return Me.columnQuantity
End Get
End Property
Friend ReadOnly Property DiscountColumn As DataColumn
Get
Return Me.columnDiscount
End Get
End Property
Public Default ReadOnly Property Item(ByVal index As Integer) As Order_DetailsRow
Get
Return CType(Me.Rows(index),Order_DetailsRow)
End Get
End Property
Public Event Order_DetailsRowChanged As Order_DetailsRowChangeEventHandler
Public Event Order_DetailsRowChanging As Order_DetailsRowChangeEventHandler
Public Event Order_DetailsRowDeleted As Order_DetailsRowChangeEventHandler
Public Event Order_DetailsRowDeleting As Order_DetailsRowChangeEventHandler
Public Overloads Sub AddOrder_DetailsRow(ByVal row As Order_DetailsRow)
Me.Rows.Add(row)
End Sub
Public Overloads Function AddOrder_DetailsRow(ByVal parentOrdersRowByOrdersOrder_x0020_Details As OrdersRow, ByVal ProductID As Integer, ByVal UnitPrice As Decimal, ByVal Quantity As Short, ByVal Discount As Single) As Order_DetailsRow
Dim rowOrder_DetailsRow As Order_DetailsRow = CType(Me.NewRow,Order_DetailsRow)
rowOrder_DetailsRow.ItemArray = New Object() {parentOrdersRowByOrdersOrder_x0020_Details(0), ProductID, UnitPrice, Quantity, Discount}
Me.Rows.Add(rowOrder_DetailsRow)
Return rowOrder_DetailsRow
End Function
Public Function FindByOrderIDProductID(ByVal OrderID As Integer, ByVal ProductID As Integer) As Order_DetailsRow
Return CType(Me.Rows.Find(New Object() {OrderID, ProductID}),Order_DetailsRow)
End Function
Public Function GetEnumerator() As System.Collections.IEnumerator Implements System.Collections.IEnumerable.GetEnumerator
Return Me.Rows.GetEnumerator
End Function
Private Sub InitClass()
Me.columnOrderID = New DataColumn("OrderID", GetType(System.Int32), "", System.Data.MappingType.Element)
Me.columnOrderID.AllowDBNull = false
Me.Columns.Add(Me.columnOrderID)
Me.columnProductID = New DataColumn("ProductID", GetType(System.Int32), "", System.Data.MappingType.Element)
Me.columnProductID.AllowDBNull = false
Me.Columns.Add(Me.columnProductID)
Me.columnUnitPrice = New DataColumn("UnitPrice", GetType(System.Decimal), "", System.Data.MappingType.Element)
Me.columnUnitPrice.AllowDBNull = false
Me.Columns.Add(Me.columnUnitPrice)
Me.columnQuantity = New DataColumn("Quantity", GetType(System.Int16), "", System.Data.MappingType.Element)
Me.columnQuantity.AllowDBNull = false
Me.Columns.Add(Me.columnQuantity)
Me.columnDiscount = New DataColumn("Discount", GetType(System.Single), "", System.Data.MappingType.Element)
Me.columnDiscount.AllowDBNull = false
Me.Columns.Add(Me.columnDiscount)
Me.PrimaryKey = New DataColumn() {Me.columnOrderID, Me.columnProductID}
End Sub
Public Function NewOrder_DetailsRow() As Order_DetailsRow
Return CType(Me.NewRow,Order_DetailsRow)
End Function
Protected Overrides Function NewRowFromBuilder(ByVal builder As DataRowBuilder) As DataRow
'We need to ensure that all Rows in the tabled are typed rows.
'Table calls newRow whenever it needs to create a row.
'So the following conditions are covered by Row newRow(Record record)
'* Cursor calls table.addRecord(record)
'* table.addRow(object[] values) calls newRow(record)
Return New Order_DetailsRow(builder)
End Function
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?