VB ch 13

Need by the weekend please!

Save Time On Research and Writing
Hire a Pro to Write You a 100% Plagiarism-Free Paper.
Get My Paper

ch13/lessona/IMG_1633.JPG

ch13/lessona/MusicBox Solution-DataGridView.zip

MusicBox Solution-DataGridView/MusicBox Project/App.config

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.exe

Save Time On Research and Writing
Hire a Pro to Write You a 100% Plagiarism-Free Paper.
Get My Paper

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.exe.config

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.pdb

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe.config

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe.manifest

MusicBox Solution-DataGridView/MusicBox Project/bin/Debug/MusicBox Project.xml

MusicBoxProject

Returns the cached ResourceManager instance used by this class.

Overrides the current thread’s CurrentUICulture property for all
resource lookups using this strongly typed resource class.

A strongly-typed resource class, for looking up localized strings, etc.

MusicBox Solution-DataGridView/MusicBox Project/Main Form.Designer.vb
_
Partial Class frmMain
Inherits System.Windows.Forms.Form
‘Form overrides dispose to clean up the component list.
_
Protected Overrides Sub Dispose(ByVal disposing As Boolean)
Try
If disposing AndAlso components IsNot Nothing Then
components.Dispose()
End If
Finally
MyBase.Dispose(disposing)
End Try
End Sub
‘Required by the Windows Form Designer
Private components As System.ComponentModel.IContainer
‘NOTE: The following procedure is required by the Windows Form Designer
‘It can be modified using the Windows Form Designer.
‘Do not modify it using the code editor.
_
Private Sub InitializeComponent()
Me.SuspendLayout()

‘frmMain

Me.AutoScaleDimensions = New System.Drawing.SizeF(7.0!, 17.0!)
Me.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font
Me.ClientSize = New System.Drawing.Size(603, 309)
Me.Font = New System.Drawing.Font(“Segoe UI”, 9.75!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(0, Byte))
Me.Margin = New System.Windows.Forms.Padding(3, 4, 3, 4)
Me.Name = “frmMain”
Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen
Me.Text = “Music Box”
Me.ResumeLayout(False)
End Sub
End Class

MusicBox Solution-DataGridView/MusicBox Project/Main Form.resx

text/microsoft-resx

2.0

System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

MusicBox Solution-DataGridView/MusicBox Project/Main Form.vb
‘ Name: MusicBox Project
‘ Purpose: Displays the records stored in a dataset
‘ Programmer: on
Option Explicit On
Option Strict On
Option Infer Off
Public Class frmMain
End Class

MusicBox Solution-DataGridView/MusicBox Project/MusicBox Project.vbproj

Debug
AnyCPU
{65B585BC-212B-41C7-A8EF-7F219FEDB877}
WinExe
MusicBox_Project.My.MyApplication
MusicBox_Project
MusicBox Project
512
WindowsForms
v4.5

AnyCPU
true
full
true
true
bin\Debug\
MusicBox Project.xml
42016,41999,42017,42018,42019,42032,42036,42020,42021,42022

AnyCPU
pdbonly
false
true
true
bin\Release\
MusicBox Project.xml
42016,41999,42017,42018,42019,42032,42036,42020,42021,42022

On

Binary

Off

On

Form

Main Form.vb
Form

True
Application.myapp

True
True
Resources.resx

True
Settings.settings
True

Main Form.vb

VbMyResourcesResXFileCodeGenerator
Resources.Designer.vb
My.Resources
Designer

MyApplicationCodeGenerator
Application.Designer.vb

SettingsSingleFileGenerator
My
Settings.Designer.vb

MusicBox Solution-DataGridView/MusicBox Project/MusicBox.accdb

Shape Source Song ID

Round Purchase As Time Goes By 1

Octagon Gift Nadia’s Theme 2

Round Purchase My Way 3

Rectangle Purchase Clair De Lune 4

Octagon Purchase Beauty and the Beast 5

Rectangle Gift Endless Love 6

Rectangle Gift Yesterday 7

Octagon Purchase You Light Up My Life 8

Rectangle Purchase Edelweiss 9

Rectangle Gift Happy Birthday 10

MusicBox Solution-DataGridView/MusicBox Project/My Project/Application.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My

‘NOTE: This file is auto-generated; do not modify it directly. To make changes,
‘ or if you encounter build errors in this file, go to the Project Designer
‘ (go to Project Properties or double-click the My Project node in
‘ Solution Explorer), and make changes on the Application tab.

Partial Friend Class MyApplication

_
Public Sub New()
MyBase.New(Global.Microsoft.VisualBasic.ApplicationServices.AuthenticationMode.Windows)
Me.IsSingleInstance = false
Me.EnableVisualStyles = true
Me.SaveMySettingsOnExit = true
Me.ShutDownStyle = Global.Microsoft.VisualBasic.ApplicationServices.ShutdownMode.AfterMainFormCloses
End Sub

_
Protected Overrides Sub OnCreateMainForm()
Me.MainForm = Global.MusicBox_Project.frmMain
End Sub
End Class
End Namespace

MusicBox Solution-DataGridView/MusicBox Project/My Project/Application.myapp


true
frmMain
false
0
true
0
true

MusicBox Solution-DataGridView/MusicBox Project/My Project/AssemblyInfo.vb
Imports System
Imports System.Reflection
Imports System.Runtime.InteropServices
‘ General Information about an assembly is controlled through the following
‘ set of attributes. Change these attribute values to modify the information
‘ associated with an assembly.
‘ Review the values of the assembly attributes







‘The following GUID is for the ID of the typelib if this project is exposed to COM

‘ Version information for an assembly consists of the following four values:

‘ Major Version
‘ Minor Version
‘ Build Number
‘ Revision

‘ You can specify all the values or you can default the Build and Revision Numbers
‘ by using the ‘*’ as shown below:


MusicBox Solution-DataGridView/MusicBox Project/My Project/Resources.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My.Resources

‘This class was auto-generated by the StronglyTypedResourceBuilder
‘class via a tool like ResGen or Visual Studio.
‘To add or remove a member, edit your .ResX file then rerun ResGen
‘with the /str option, or rebuild your VS project.
”’

”’ A strongly-typed resource class, for looking up localized strings, etc.
”’

_
Friend Module Resources
Private resourceMan As Global.System.Resources.ResourceManager
Private resourceCulture As Global.System.Globalization.CultureInfo
”’

”’ Returns the cached ResourceManager instance used by this class.
”’

_
Friend ReadOnly Property ResourceManager() As Global.System.Resources.ResourceManager
Get
If Object.ReferenceEquals(resourceMan, Nothing) Then
Dim temp As Global.System.Resources.ResourceManager = New Global.System.Resources.ResourceManager(“MusicBox_Project.Resources”, GetType(Resources).Assembly)
resourceMan = temp
End If
Return resourceMan
End Get
End Property
”’

”’ Overrides the current thread’s CurrentUICulture property for all
”’ resource lookups using this strongly typed resource class.
”’

_
Friend Property Culture() As Global.System.Globalization.CultureInfo
Get
Return resourceCulture
End Get
Set(ByVal value As Global.System.Globalization.CultureInfo)
resourceCulture = value
End Set
End Property
End Module
End Namespace

MusicBox Solution-DataGridView/MusicBox Project/My Project/Resources.resx

text/microsoft-resx

2.0

System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

MusicBox Solution-DataGridView/MusicBox Project/My Project/Settings.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My
_
Partial Friend NotInheritable Class MySettings
Inherits Global.System.Configuration.ApplicationSettingsBase
Private Shared defaultInstance As MySettings = CType(Global.System.Configuration.ApplicationSettingsBase.Synchronized(New MySettings), MySettings)
#Region “My.Settings Auto-Save Functionality”
#If _MyType = “WindowsForms” Then
Private Shared addedHandler As Boolean
Private Shared addedHandlerLockObject As New Object
_
Private Shared Sub AutoSaveSettings(ByVal sender As Global.System.Object, ByVal e As Global.System.EventArgs)
If My.Application.SaveMySettingsOnExit Then
My.Settings.Save()
End If
End Sub
#End If
#End Region
Public Shared ReadOnly Property [Default]() As MySettings
Get
#If _MyType = “WindowsForms” Then
If Not addedHandler Then
SyncLock addedHandlerLockObject
If Not addedHandler Then
AddHandler My.Application.Shutdown, AddressOf AutoSaveSettings
addedHandler = True
End If
End SyncLock
End If
#End If
Return defaultInstance
End Get
End Property
End Class
End Namespace
Namespace My

_
Friend Module MySettingsProperty

_
Friend ReadOnly Property Settings() As Global.MusicBox_Project.My.MySettings
Get
Return Global.MusicBox_Project.My.MySettings.Default
End Get
End Property
End Module
End Namespace

MusicBox Solution-DataGridView/MusicBox Project/My Project/Settings.settings

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/DesignTimeResolveAssemblyReferences.cache

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox Project.exe

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox Project.pdb

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox Project.vbproj.FileListAbsolute.txt
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\bin\Debug\MusicBox Project.exe.config
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\bin\Debug\MusicBox Project.exe
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\bin\Debug\MusicBox Project.pdb
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\bin\Debug\MusicBox Project.xml
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox_Project.frmMain.resources
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox_Project.Resources.resources
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox Project.vbproj.GenerateResource.Cache
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox Project.exe
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox Project.xml
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-DataGridView\MusicBox Project\obj\Debug\MusicBox Project.pdb

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox Project.vbproj.GenerateResource.Cache

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox Project.xml

MusicBoxProject

Returns the cached ResourceManager instance used by this class.

Overrides the current thread’s CurrentUICulture property for all
resource lookups using this strongly typed resource class.

A strongly-typed resource class, for looking up localized strings, etc.

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox_Project.frmMain.resources

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/MusicBox_Project.Resources.resources

MusicBox Solution-DataGridView/MusicBox Project/obj/Debug/TempPE/My Project.Resources.Designer.vb.dll

MusicBox Solution-DataGridView/MusicBox Solution.sln

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio 2012
Project(“{F184B08F-C81C-45F6-A57F-5ABD9991F28F}”) = “MusicBox Project”, “MusicBox Project\MusicBox Project.vbproj”, “{65B585BC-212B-41C7-A8EF-7F219FEDB877}”
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Release|Any CPU = Release|Any CPU
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{65B585BC-212B-41C7-A8EF-7F219FEDB877}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{65B585BC-212B-41C7-A8EF-7F219FEDB877}.Debug|Any CPU.Build.0 = Debug|Any CPU
{65B585BC-212B-41C7-A8EF-7F219FEDB877}.Release|Any CPU.ActiveCfg = Release|Any CPU
{65B585BC-212B-41C7-A8EF-7F219FEDB877}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
EndGlobal

MusicBox Solution-DataGridView/MusicBox Solution.v11.suo

ch13/lessonb/IMG_1634.JPG

ch13/lessonb/MusicBox Solution-LINQ.zip

MusicBox Solution-LINQ/MusicBox Project/App.config

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.exe

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.exe.config

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.pdb

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe.config

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.vshost.exe.manifest

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox Project.xml

MusicBoxProject

Represents the strongly named DataTable class.

Represents strongly named DataRow class.

Row event argument class

Represents a strongly typed in-memory cache of data.

Represents the connection and commands used to retrieve and save data.

Update rows in top-down order.

Insert rows in top-down order.

Delete rows in bottom-up order.

Remove inserted rows that become updated rows after calling TableAdapter.Update(inserted rows) first

Update all changes to the dataset.

Update Order Option

Used to sort self-referenced table’s rows

TableAdapterManager is used to coordinate TableAdapters in the dataset to enable Hierarchical Update scenarios

Returns the cached ResourceManager instance used by this class.

Overrides the current thread’s CurrentUICulture property for all
resource lookups using this strongly typed resource class.

A strongly-typed resource class, for looking up localized strings, etc.

MusicBox Solution-LINQ/MusicBox Project/bin/Debug/MusicBox.accdb

Shape Source Song ID

Round Purchase As Time Goes By 1

Octagon Gift Nadia’s Theme 2

Round Purchase My Way 3

Rectangle Purchase Clair De Lune 4

Octagon Purchase Beauty and the Beast 5

Rectangle Gift Endless Love 6

Rectangle Gift Yesterday 7

Octagon Purchase You Light Up My Life 8

Rectangle Purchase Edelweiss 9

Rectangle Gift Happy Birthday 10

MusicBox Solution-LINQ/MusicBox Project/Main Form.Designer.vb
_
Partial Class frmMain
Inherits System.Windows.Forms.Form
‘Form overrides dispose to clean up the component list.
_
Protected Overrides Sub Dispose(ByVal disposing As Boolean)
Try
If disposing AndAlso components IsNot Nothing Then
components.Dispose()
End If
Finally
MyBase.Dispose(disposing)
End Try
End Sub
‘Required by the Windows Form Designer
Private components As System.ComponentModel.IContainer
‘NOTE: The following procedure is required by the Windows Form Designer
‘It can be modified using the Windows Form Designer.
‘Do not modify it using the code editor.
_
Private Sub InitializeComponent()
Me.components = New System.ComponentModel.Container()
Me.MusicBoxDataSet = New MusicBox_Project.MusicBoxDataSet()
Me.TblBoxBindingSource = New System.Windows.Forms.BindingSource(Me.components)
Me.TblBoxTableAdapter = New MusicBox_Project.MusicBoxDataSetTableAdapters.tblBoxTableAdapter()
Me.TableAdapterManager = New MusicBox_Project.MusicBoxDataSetTableAdapters.TableAdapterManager()
Me.TblBoxDataGridView = New System.Windows.Forms.DataGridView()
Me.DataGridViewTextBoxColumn1 = New System.Windows.Forms.DataGridViewTextBoxColumn()
Me.DataGridViewTextBoxColumn2 = New System.Windows.Forms.DataGridViewTextBoxColumn()
Me.DataGridViewTextBoxColumn3 = New System.Windows.Forms.DataGridViewTextBoxColumn()
Me.DataGridViewTextBoxColumn4 = New System.Windows.Forms.DataGridViewTextBoxColumn()
Me.btnAll = New System.Windows.Forms.Button()
Me.btnShape = New System.Windows.Forms.Button()
Me.btnSource = New System.Windows.Forms.Button()
Me.radGift = New System.Windows.Forms.RadioButton()
Me.radPurchased = New System.Windows.Forms.RadioButton()
Me.radOctagon = New System.Windows.Forms.RadioButton()
Me.GroupBox1 = New System.Windows.Forms.GroupBox()
Me.radRound = New System.Windows.Forms.RadioButton()
Me.radRectangle = New System.Windows.Forms.RadioButton()
Me.GroupBox2 = New System.Windows.Forms.GroupBox()
Me.btnExit = New System.Windows.Forms.Button()
Me.btnCount = New System.Windows.Forms.Button()
CType(Me.MusicBoxDataSet, System.ComponentModel.ISupportInitialize).BeginInit()
CType(Me.TblBoxBindingSource, System.ComponentModel.ISupportInitialize).BeginInit()
CType(Me.TblBoxDataGridView, System.ComponentModel.ISupportInitialize).BeginInit()
Me.GroupBox1.SuspendLayout()
Me.GroupBox2.SuspendLayout()
Me.SuspendLayout()

‘MusicBoxDataSet

Me.MusicBoxDataSet.DataSetName = “MusicBoxDataSet”
Me.MusicBoxDataSet.SchemaSerializationMode = System.Data.SchemaSerializationMode.IncludeSchema

‘TblBoxBindingSource

Me.TblBoxBindingSource.DataMember = “tblBox”
Me.TblBoxBindingSource.DataSource = Me.MusicBoxDataSet

‘TblBoxTableAdapter

Me.TblBoxTableAdapter.ClearBeforeFill = True

‘TableAdapterManager

Me.TableAdapterManager.BackupDataSetBeforeUpdate = False
Me.TableAdapterManager.tblBoxTableAdapter = Me.TblBoxTableAdapter
Me.TableAdapterManager.UpdateOrder = MusicBox_Project.MusicBoxDataSetTableAdapters.TableAdapterManager.UpdateOrderOption.InsertUpdateDelete

‘TblBoxDataGridView

Me.TblBoxDataGridView.AllowUserToAddRows = False
Me.TblBoxDataGridView.AllowUserToDeleteRows = False
Me.TblBoxDataGridView.AutoGenerateColumns = False
Me.TblBoxDataGridView.AutoSizeColumnsMode = System.Windows.Forms.DataGridViewAutoSizeColumnsMode.Fill
Me.TblBoxDataGridView.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize
Me.TblBoxDataGridView.Columns.AddRange(New System.Windows.Forms.DataGridViewColumn() {Me.DataGridViewTextBoxColumn1, Me.DataGridViewTextBoxColumn2, Me.DataGridViewTextBoxColumn3, Me.DataGridViewTextBoxColumn4})
Me.TblBoxDataGridView.DataSource = Me.TblBoxBindingSource
Me.TblBoxDataGridView.Location = New System.Drawing.Point(22, 15)
Me.TblBoxDataGridView.Name = “TblBoxDataGridView”
Me.TblBoxDataGridView.ReadOnly = True
Me.TblBoxDataGridView.RowHeadersVisible = False
Me.TblBoxDataGridView.SelectionMode = System.Windows.Forms.DataGridViewSelectionMode.FullRowSelect
Me.TblBoxDataGridView.Size = New System.Drawing.Size(563, 271)
Me.TblBoxDataGridView.TabIndex = 5

‘DataGridViewTextBoxColumn1

Me.DataGridViewTextBoxColumn1.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.AllCells
Me.DataGridViewTextBoxColumn1.DataPropertyName = “ID”
Me.DataGridViewTextBoxColumn1.HeaderText = “ID”
Me.DataGridViewTextBoxColumn1.Name = “DataGridViewTextBoxColumn1”
Me.DataGridViewTextBoxColumn1.ReadOnly = True
Me.DataGridViewTextBoxColumn1.Width = 45

‘DataGridViewTextBoxColumn2

Me.DataGridViewTextBoxColumn2.DataPropertyName = “Shape”
Me.DataGridViewTextBoxColumn2.HeaderText = “Shape”
Me.DataGridViewTextBoxColumn2.Name = “DataGridViewTextBoxColumn2”
Me.DataGridViewTextBoxColumn2.ReadOnly = True

‘DataGridViewTextBoxColumn3

Me.DataGridViewTextBoxColumn3.DataPropertyName = “Source”
Me.DataGridViewTextBoxColumn3.HeaderText = “Source”
Me.DataGridViewTextBoxColumn3.Name = “DataGridViewTextBoxColumn3”
Me.DataGridViewTextBoxColumn3.ReadOnly = True

‘DataGridViewTextBoxColumn4

Me.DataGridViewTextBoxColumn4.DataPropertyName = “Song”
Me.DataGridViewTextBoxColumn4.HeaderText = “Song”
Me.DataGridViewTextBoxColumn4.Name = “DataGridViewTextBoxColumn4”
Me.DataGridViewTextBoxColumn4.ReadOnly = True

‘btnAll

Me.btnAll.Location = New System.Drawing.Point(614, 23)
Me.btnAll.Name = “btnAll”
Me.btnAll.Size = New System.Drawing.Size(111, 30)
Me.btnAll.TabIndex = 0
Me.btnAll.Text = “&All Records”
Me.btnAll.UseVisualStyleBackColor = True

‘btnShape

Me.btnShape.Location = New System.Drawing.Point(15, 105)
Me.btnShape.Name = “btnShape”
Me.btnShape.Size = New System.Drawing.Size(111, 30)
Me.btnShape.TabIndex = 3
Me.btnShape.Text = “S&hape”
Me.btnShape.UseVisualStyleBackColor = True

‘btnSource

Me.btnSource.Location = New System.Drawing.Point(6, 87)
Me.btnSource.Name = “btnSource”
Me.btnSource.Size = New System.Drawing.Size(111, 30)
Me.btnSource.TabIndex = 2
Me.btnSource.Text = “&Source”
Me.btnSource.UseVisualStyleBackColor = True

‘radGift

Me.radGift.AutoSize = True
Me.radGift.Checked = True
Me.radGift.Location = New System.Drawing.Point(11, 24)
Me.radGift.Name = “radGift”
Me.radGift.Size = New System.Drawing.Size(46, 21)
Me.radGift.TabIndex = 0
Me.radGift.TabStop = True
Me.radGift.Text = “&Gift”
Me.radGift.UseVisualStyleBackColor = True

‘radPurchased

Me.radPurchased.AutoSize = True
Me.radPurchased.Location = New System.Drawing.Point(11, 51)
Me.radPurchased.Name = “radPurchased”
Me.radPurchased.Size = New System.Drawing.Size(86, 21)
Me.radPurchased.TabIndex = 1
Me.radPurchased.Text = “&Purchased”
Me.radPurchased.UseVisualStyleBackColor = True

‘radOctagon

Me.radOctagon.AutoSize = True
Me.radOctagon.Checked = True
Me.radOctagon.Location = New System.Drawing.Point(15, 19)
Me.radOctagon.Name = “radOctagon”
Me.radOctagon.Size = New System.Drawing.Size(76, 21)
Me.radOctagon.TabIndex = 0
Me.radOctagon.TabStop = True
Me.radOctagon.Text = “&Octagon”
Me.radOctagon.UseVisualStyleBackColor = True

‘GroupBox1

Me.GroupBox1.Controls.Add(Me.radRound)
Me.GroupBox1.Controls.Add(Me.radRectangle)
Me.GroupBox1.Controls.Add(Me.radOctagon)
Me.GroupBox1.Controls.Add(Me.btnShape)
Me.GroupBox1.Location = New System.Drawing.Point(614, 76)
Me.GroupBox1.Name = “GroupBox1”
Me.GroupBox1.Size = New System.Drawing.Size(142, 148)
Me.GroupBox1.TabIndex = 2
Me.GroupBox1.TabStop = False

‘radRound

Me.radRound.AutoSize = True
Me.radRound.Location = New System.Drawing.Point(15, 73)
Me.radRound.Name = “radRound”
Me.radRound.Size = New System.Drawing.Size(64, 21)
Me.radRound.TabIndex = 2
Me.radRound.Text = “Roun&d”
Me.radRound.UseVisualStyleBackColor = True

‘radRectangle

Me.radRectangle.AutoSize = True
Me.radRectangle.Location = New System.Drawing.Point(15, 46)
Me.radRectangle.Name = “radRectangle”
Me.radRectangle.Size = New System.Drawing.Size(83, 21)
Me.radRectangle.TabIndex = 1
Me.radRectangle.Text = “&Rectangle”
Me.radRectangle.UseVisualStyleBackColor = True

‘GroupBox2

Me.GroupBox2.Controls.Add(Me.radGift)
Me.GroupBox2.Controls.Add(Me.radPurchased)
Me.GroupBox2.Controls.Add(Me.btnSource)
Me.GroupBox2.Location = New System.Drawing.Point(786, 76)
Me.GroupBox2.Name = “GroupBox2”
Me.GroupBox2.Size = New System.Drawing.Size(127, 137)
Me.GroupBox2.TabIndex = 3
Me.GroupBox2.TabStop = False

‘btnExit

Me.btnExit.Location = New System.Drawing.Point(792, 228)
Me.btnExit.Name = “btnExit”
Me.btnExit.Size = New System.Drawing.Size(111, 30)
Me.btnExit.TabIndex = 4
Me.btnExit.Text = “E&xit”
Me.btnExit.UseVisualStyleBackColor = True

‘btnCount

Me.btnCount.Location = New System.Drawing.Point(792, 23)
Me.btnCount.Name = “btnCount”
Me.btnCount.Size = New System.Drawing.Size(111, 30)
Me.btnCount.TabIndex = 1
Me.btnCount.Text = “&Count”
Me.btnCount.UseVisualStyleBackColor = True

‘frmMain

Me.AutoScaleDimensions = New System.Drawing.SizeF(7.0!, 17.0!)
Me.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font
Me.ClientSize = New System.Drawing.Size(946, 311)
Me.Controls.Add(Me.btnCount)
Me.Controls.Add(Me.btnExit)
Me.Controls.Add(Me.GroupBox2)
Me.Controls.Add(Me.GroupBox1)
Me.Controls.Add(Me.btnAll)
Me.Controls.Add(Me.TblBoxDataGridView)
Me.Font = New System.Drawing.Font(“Segoe UI”, 9.75!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(0, Byte))
Me.Margin = New System.Windows.Forms.Padding(3, 4, 3, 4)
Me.Name = “frmMain”
Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen
Me.Text = “Music Box”
CType(Me.MusicBoxDataSet, System.ComponentModel.ISupportInitialize).EndInit()
CType(Me.TblBoxBindingSource, System.ComponentModel.ISupportInitialize).EndInit()
CType(Me.TblBoxDataGridView, System.ComponentModel.ISupportInitialize).EndInit()
Me.GroupBox1.ResumeLayout(False)
Me.GroupBox1.PerformLayout()
Me.GroupBox2.ResumeLayout(False)
Me.GroupBox2.PerformLayout()
Me.ResumeLayout(False)
End Sub
Friend WithEvents MusicBoxDataSet As MusicBox_Project.MusicBoxDataSet
Friend WithEvents TblBoxBindingSource As System.Windows.Forms.BindingSource
Friend WithEvents TblBoxTableAdapter As MusicBox_Project.MusicBoxDataSetTableAdapters.tblBoxTableAdapter
Friend WithEvents TableAdapterManager As MusicBox_Project.MusicBoxDataSetTableAdapters.TableAdapterManager
Friend WithEvents TblBoxDataGridView As System.Windows.Forms.DataGridView
Friend WithEvents DataGridViewTextBoxColumn1 As System.Windows.Forms.DataGridViewTextBoxColumn
Friend WithEvents DataGridViewTextBoxColumn2 As System.Windows.Forms.DataGridViewTextBoxColumn
Friend WithEvents DataGridViewTextBoxColumn3 As System.Windows.Forms.DataGridViewTextBoxColumn
Friend WithEvents DataGridViewTextBoxColumn4 As System.Windows.Forms.DataGridViewTextBoxColumn
Friend WithEvents btnAll As System.Windows.Forms.Button
Friend WithEvents btnShape As System.Windows.Forms.Button
Friend WithEvents btnSource As System.Windows.Forms.Button
Friend WithEvents radGift As System.Windows.Forms.RadioButton
Friend WithEvents radPurchased As System.Windows.Forms.RadioButton
Friend WithEvents radOctagon As System.Windows.Forms.RadioButton
Friend WithEvents GroupBox1 As System.Windows.Forms.GroupBox
Friend WithEvents radRound As System.Windows.Forms.RadioButton
Friend WithEvents radRectangle As System.Windows.Forms.RadioButton
Friend WithEvents GroupBox2 As System.Windows.Forms.GroupBox
Friend WithEvents btnExit As System.Windows.Forms.Button
Friend WithEvents btnCount As System.Windows.Forms.Button
End Class

MusicBox Solution-LINQ/MusicBox Project/Main Form.resx

text/microsoft-resx

2.0

System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

17, 17

163, 17

330, 17

491, 17

True

True

True

True

True

True

True

True

True

True

True

True

True

True

MusicBox Solution-LINQ/MusicBox Project/Main Form.vb
‘ Name: MusicBox Project
‘ Purpose: Selects specific records
‘ Also displays the number of music boxes
‘ Programmer: on
Option Explicit On
Option Strict On
Option Infer On ‘ using LINQ
Public Class frmMain
Private Sub frmMain_Load(sender As Object, e As EventArgs) Handles MyBase.Load
‘TODO: This line of code loads data into the ‘MusicBoxDataSet.tblBox’ table. You can move, or remove it, as needed.
Me.TblBoxTableAdapter.Fill(Me.MusicBoxDataSet.tblBox)
End Sub
Private Sub btnAll_Click(sender As Object, e As EventArgs) Handles btnAll.Click
‘ displays all of the records

End Sub
Private Sub btnShape_Click(sender As Object, e As EventArgs) Handles btnShape.Click
‘ displays music boxes having the selected shape

End Sub
Private Sub btnSource_Click(sender As Object, e As EventArgs) Handles btnSource.Click
‘ displays either gift music boxes or purchased music boxes

End Sub
Private Sub btnCount_Click(sender As Object, e As EventArgs) Handles btnCount.Click
‘ displays the number of music boxes

End Sub
Private Sub btnExit_Click(sender As Object, e As EventArgs) Handles btnExit.Click
Me.Close()
End Sub
End Class

MusicBox Solution-LINQ/MusicBox Project/MusicBox Project.vbproj

Debug
AnyCPU
{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}
WinExe
MusicBox_Project.My.MyApplication
MusicBox_Project
MusicBox Project
512
WindowsForms
v4.5

AnyCPU
true
full
true
true
bin\Debug\
MusicBox Project.xml
42016,41999,42017,42018,42019,42032,42036,42020,42021,42022

AnyCPU
pdbonly
false
true
true
bin\Release\
MusicBox Project.xml
42016,41999,42017,42018,42019,42032,42036,42020,42021,42022

On

Binary

Off

On

Form

Main Form.vb
Form

True
True
MusicBoxDataSet.xsd

True
Application.myapp

True
True
Resources.resx

True
Settings.settings
True

Main Form.vb

VbMyResourcesResXFileCodeGenerator
Resources.Designer.vb
My.Resources
Designer

MusicBoxDataSet.xsd

MSDataSetGenerator
MusicBoxDataSet.Designer.vb
Designer

MusicBoxDataSet.xsd

MyApplicationCodeGenerator
Application.Designer.vb

SettingsSingleFileGenerator
My
Settings.Designer.vb

Always

MusicBox Solution-LINQ/MusicBox Project/MusicBox.accdb

Shape Source Song ID

Round Purchase As Time Goes By 1

Octagon Gift Nadia’s Theme 2

Round Purchase My Way 3

Rectangle Purchase Clair De Lune 4

Octagon Purchase Beauty and the Beast 5

Rectangle Gift Endless Love 6

Rectangle Gift Yesterday 7

Octagon Purchase You Light Up My Life 8

Rectangle Purchase Edelweiss 9

Rectangle Gift Happy Birthday 10

MusicBox Solution-LINQ/MusicBox Project/MusicBoxDataSet.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict Off
Option Explicit On

”’

”’Represents a strongly typed in-memory cache of data.
”’

_
Partial Public Class MusicBoxDataSet
Inherits Global.System.Data.DataSet

Private tabletblBox As tblBoxDataTable

Private _schemaSerializationMode As Global.System.Data.SchemaSerializationMode = Global.System.Data.SchemaSerializationMode.IncludeSchema

_
Public Sub New()
MyBase.New
Me.BeginInit
Me.InitClass
Dim schemaChangedHandler As Global.System.ComponentModel.CollectionChangeEventHandler = AddressOf Me.SchemaChanged
AddHandler MyBase.Tables.CollectionChanged, schemaChangedHandler
AddHandler MyBase.Relations.CollectionChanged, schemaChangedHandler
Me.EndInit
End Sub

_
Protected Sub New(ByVal info As Global.System.Runtime.Serialization.SerializationInfo, ByVal context As Global.System.Runtime.Serialization.StreamingContext)
MyBase.New(info, context, false)
If (Me.IsBinarySerialized(info, context) = true) Then
Me.InitVars(false)
Dim schemaChangedHandler1 As Global.System.ComponentModel.CollectionChangeEventHandler = AddressOf Me.SchemaChanged
AddHandler Me.Tables.CollectionChanged, schemaChangedHandler1
AddHandler Me.Relations.CollectionChanged, schemaChangedHandler1
Return
End If
Dim strSchema As String = CType(info.GetValue(“XmlSchema”, GetType(String)),String)
If (Me.DetermineSchemaSerializationMode(info, context) = Global.System.Data.SchemaSerializationMode.IncludeSchema) Then
Dim ds As Global.System.Data.DataSet = New Global.System.Data.DataSet()
ds.ReadXmlSchema(New Global.System.Xml.XmlTextReader(New Global.System.IO.StringReader(strSchema)))
If (Not (ds.Tables(“tblBox”)) Is Nothing) Then
MyBase.Tables.Add(New tblBoxDataTable(ds.Tables(“tblBox”)))
End If
Me.DataSetName = ds.DataSetName
Me.Prefix = ds.Prefix
Me.Namespace = ds.Namespace
Me.Locale = ds.Locale
Me.CaseSensitive = ds.CaseSensitive
Me.EnforceConstraints = ds.EnforceConstraints
Me.Merge(ds, false, Global.System.Data.MissingSchemaAction.Add)
Me.InitVars
Else
Me.ReadXmlSchema(New Global.System.Xml.XmlTextReader(New Global.System.IO.StringReader(strSchema)))
End If
Me.GetSerializationData(info, context)
Dim schemaChangedHandler As Global.System.ComponentModel.CollectionChangeEventHandler = AddressOf Me.SchemaChanged
AddHandler MyBase.Tables.CollectionChanged, schemaChangedHandler
AddHandler Me.Relations.CollectionChanged, schemaChangedHandler
End Sub

_
Public ReadOnly Property tblBox() As tblBoxDataTable
Get
Return Me.tabletblBox
End Get
End Property

_
Public Overrides Property SchemaSerializationMode() As Global.System.Data.SchemaSerializationMode
Get
Return Me._schemaSerializationMode
End Get
Set
Me._schemaSerializationMode = value
End Set
End Property

_
Public Shadows ReadOnly Property Tables() As Global.System.Data.DataTableCollection
Get
Return MyBase.Tables
End Get
End Property

_
Public Shadows ReadOnly Property Relations() As Global.System.Data.DataRelationCollection
Get
Return MyBase.Relations
End Get
End Property

_
Protected Overrides Sub InitializeDerivedDataSet()
Me.BeginInit
Me.InitClass
Me.EndInit
End Sub

_
Public Overrides Function Clone() As Global.System.Data.DataSet
Dim cln As MusicBoxDataSet = CType(MyBase.Clone,MusicBoxDataSet)
cln.InitVars
cln.SchemaSerializationMode = Me.SchemaSerializationMode
Return cln
End Function

_
Protected Overrides Function ShouldSerializeTables() As Boolean
Return false
End Function

_
Protected Overrides Function ShouldSerializeRelations() As Boolean
Return false
End Function

_
Protected Overrides Sub ReadXmlSerializable(ByVal reader As Global.System.Xml.XmlReader)
If (Me.DetermineSchemaSerializationMode(reader) = Global.System.Data.SchemaSerializationMode.IncludeSchema) Then
Me.Reset
Dim ds As Global.System.Data.DataSet = New Global.System.Data.DataSet()
ds.ReadXml(reader)
If (Not (ds.Tables(“tblBox”)) Is Nothing) Then
MyBase.Tables.Add(New tblBoxDataTable(ds.Tables(“tblBox”)))
End If
Me.DataSetName = ds.DataSetName
Me.Prefix = ds.Prefix
Me.Namespace = ds.Namespace
Me.Locale = ds.Locale
Me.CaseSensitive = ds.CaseSensitive
Me.EnforceConstraints = ds.EnforceConstraints
Me.Merge(ds, false, Global.System.Data.MissingSchemaAction.Add)
Me.InitVars
Else
Me.ReadXml(reader)
Me.InitVars
End If
End Sub

_
Protected Overrides Function GetSchemaSerializable() As Global.System.Xml.Schema.XmlSchema
Dim stream As Global.System.IO.MemoryStream = New Global.System.IO.MemoryStream()
Me.WriteXmlSchema(New Global.System.Xml.XmlTextWriter(stream, Nothing))
stream.Position = 0
Return Global.System.Xml.Schema.XmlSchema.Read(New Global.System.Xml.XmlTextReader(stream), Nothing)
End Function

_
Friend Overloads Sub InitVars()
Me.InitVars(true)
End Sub

_
Friend Overloads Sub InitVars(ByVal initTable As Boolean)
Me.tabletblBox = CType(MyBase.Tables(“tblBox”),tblBoxDataTable)
If (initTable = true) Then
If (Not (Me.tabletblBox) Is Nothing) Then
Me.tabletblBox.InitVars
End If
End If
End Sub

_
Private Sub InitClass()
Me.DataSetName = “MusicBoxDataSet”
Me.Prefix = “”
Me.Namespace = “http://tempuri.org/MusicBoxDataSet.xsd”
Me.EnforceConstraints = true
Me.SchemaSerializationMode = Global.System.Data.SchemaSerializationMode.IncludeSchema
Me.tabletblBox = New tblBoxDataTable()
MyBase.Tables.Add(Me.tabletblBox)
End Sub

_
Private Function ShouldSerializetblBox() As Boolean
Return false
End Function

_
Private Sub SchemaChanged(ByVal sender As Object, ByVal e As Global.System.ComponentModel.CollectionChangeEventArgs)
If (e.Action = Global.System.ComponentModel.CollectionChangeAction.Remove) Then
Me.InitVars
End If
End Sub

_
Public Shared Function GetTypedDataSetSchema(ByVal xs As Global.System.Xml.Schema.XmlSchemaSet) As Global.System.Xml.Schema.XmlSchemaComplexType
Dim ds As MusicBoxDataSet = New MusicBoxDataSet()
Dim type As Global.System.Xml.Schema.XmlSchemaComplexType = New Global.System.Xml.Schema.XmlSchemaComplexType()
Dim sequence As Global.System.Xml.Schema.XmlSchemaSequence = New Global.System.Xml.Schema.XmlSchemaSequence()
Dim any As Global.System.Xml.Schema.XmlSchemaAny = New Global.System.Xml.Schema.XmlSchemaAny()
any.Namespace = ds.Namespace
sequence.Items.Add(any)
type.Particle = sequence
Dim dsSchema As Global.System.Xml.Schema.XmlSchema = ds.GetSchemaSerializable
If xs.Contains(dsSchema.TargetNamespace) Then
Dim s1 As Global.System.IO.MemoryStream = New Global.System.IO.MemoryStream()
Dim s2 As Global.System.IO.MemoryStream = New Global.System.IO.MemoryStream()
Try
Dim schema As Global.System.Xml.Schema.XmlSchema = Nothing
dsSchema.Write(s1)
Dim schemas As Global.System.Collections.IEnumerator = xs.Schemas(dsSchema.TargetNamespace).GetEnumerator
Do While schemas.MoveNext
schema = CType(schemas.Current,Global.System.Xml.Schema.XmlSchema)
s2.SetLength(0)
schema.Write(s2)
If (s1.Length = s2.Length) Then
s1.Position = 0
s2.Position = 0

Do While ((s1.Position <> s1.Length) _
AndAlso (s1.ReadByte = s2.ReadByte))

Loop
If (s1.Position = s1.Length) Then
Return type
End If
End If

Loop
Finally
If (Not (s1) Is Nothing) Then
s1.Close
End If
If (Not (s2) Is Nothing) Then
s2.Close
End If
End Try
End If
xs.Add(dsSchema)
Return type
End Function

_
Public Delegate Sub tblBoxRowChangeEventHandler(ByVal sender As Object, ByVal e As tblBoxRowChangeEvent)

”’

”’Represents the strongly named DataTable class.
”’

_
Partial Public Class tblBoxDataTable
Inherits Global.System.Data.TypedTableBase(Of tblBoxRow)

Private columnID As Global.System.Data.DataColumn

Private columnShape As Global.System.Data.DataColumn

Private columnSource As Global.System.Data.DataColumn

Private columnSong As Global.System.Data.DataColumn

_
Public Sub New()
MyBase.New
Me.TableName = “tblBox”
Me.BeginInit
Me.InitClass
Me.EndInit
End Sub

_
Friend Sub New(ByVal table As Global.System.Data.DataTable)
MyBase.New
Me.TableName = table.TableName
If (table.CaseSensitive <> table.DataSet.CaseSensitive) Then
Me.CaseSensitive = table.CaseSensitive
End If
If (table.Locale.ToString <> table.DataSet.Locale.ToString) Then
Me.Locale = table.Locale
End If
If (table.Namespace <> table.DataSet.Namespace) Then
Me.Namespace = table.Namespace
End If
Me.Prefix = table.Prefix
Me.MinimumCapacity = table.MinimumCapacity
End Sub

_
Protected Sub New(ByVal info As Global.System.Runtime.Serialization.SerializationInfo, ByVal context As Global.System.Runtime.Serialization.StreamingContext)
MyBase.New(info, context)
Me.InitVars
End Sub

_
Public ReadOnly Property IDColumn() As Global.System.Data.DataColumn
Get
Return Me.columnID
End Get
End Property

_
Public ReadOnly Property ShapeColumn() As Global.System.Data.DataColumn
Get
Return Me.columnShape
End Get
End Property

_
Public ReadOnly Property SourceColumn() As Global.System.Data.DataColumn
Get
Return Me.columnSource
End Get
End Property

_
Public ReadOnly Property SongColumn() As Global.System.Data.DataColumn
Get
Return Me.columnSong
End Get
End Property

_
Public ReadOnly Property Count() As Integer
Get
Return Me.Rows.Count
End Get
End Property

_
Public Default ReadOnly Property Item(ByVal index As Integer) As tblBoxRow
Get
Return CType(Me.Rows(index),tblBoxRow)
End Get
End Property

_
Public Event tblBoxRowChanging As tblBoxRowChangeEventHandler

_
Public Event tblBoxRowChanged As tblBoxRowChangeEventHandler

_
Public Event tblBoxRowDeleting As tblBoxRowChangeEventHandler

_
Public Event tblBoxRowDeleted As tblBoxRowChangeEventHandler

_
Public Overloads Sub AddtblBoxRow(ByVal row As tblBoxRow)
Me.Rows.Add(row)
End Sub

_
Public Overloads Function AddtblBoxRow(ByVal ID As String, ByVal Shape As String, ByVal Source As String, ByVal Song As String) As tblBoxRow
Dim rowtblBoxRow As tblBoxRow = CType(Me.NewRow,tblBoxRow)
Dim columnValuesArray() As Object = New Object() {ID, Shape, Source, Song}
rowtblBoxRow.ItemArray = columnValuesArray
Me.Rows.Add(rowtblBoxRow)
Return rowtblBoxRow
End Function

_
Public Function FindByID(ByVal ID As String) As tblBoxRow
Return CType(Me.Rows.Find(New Object() {ID}),tblBoxRow)
End Function

_
Public Overrides Function Clone() As Global.System.Data.DataTable
Dim cln As tblBoxDataTable = CType(MyBase.Clone,tblBoxDataTable)
cln.InitVars
Return cln
End Function

_
Protected Overrides Function CreateInstance() As Global.System.Data.DataTable
Return New tblBoxDataTable()
End Function

_
Friend Sub InitVars()
Me.columnID = MyBase.Columns(“ID”)
Me.columnShape = MyBase.Columns(“Shape”)
Me.columnSource = MyBase.Columns(“Source”)
Me.columnSong = MyBase.Columns(“Song”)
End Sub

_
Private Sub InitClass()
Me.columnID = New Global.System.Data.DataColumn(“ID”, GetType(String), Nothing, Global.System.Data.MappingType.Element)
MyBase.Columns.Add(Me.columnID)
Me.columnShape = New Global.System.Data.DataColumn(“Shape”, GetType(String), Nothing, Global.System.Data.MappingType.Element)
MyBase.Columns.Add(Me.columnShape)
Me.columnSource = New Global.System.Data.DataColumn(“Source”, GetType(String), Nothing, Global.System.Data.MappingType.Element)
MyBase.Columns.Add(Me.columnSource)
Me.columnSong = New Global.System.Data.DataColumn(“Song”, GetType(String), Nothing, Global.System.Data.MappingType.Element)
MyBase.Columns.Add(Me.columnSong)
Me.Constraints.Add(New Global.System.Data.UniqueConstraint(“Constraint1”, New Global.System.Data.DataColumn() {Me.columnID}, true))
Me.columnID.AllowDBNull = false
Me.columnID.Unique = true
Me.columnID.MaxLength = 255
Me.columnShape.MaxLength = 255
Me.columnSource.MaxLength = 255
Me.columnSong.MaxLength = 255
End Sub

_
Public Function NewtblBoxRow() As tblBoxRow
Return CType(Me.NewRow,tblBoxRow)
End Function

_
Protected Overrides Function NewRowFromBuilder(ByVal builder As Global.System.Data.DataRowBuilder) As Global.System.Data.DataRow
Return New tblBoxRow(builder)
End Function

_
Protected Overrides Function GetRowType() As Global.System.Type
Return GetType(tblBoxRow)
End Function

_
Protected Overrides Sub OnRowChanged(ByVal e As Global.System.Data.DataRowChangeEventArgs)
MyBase.OnRowChanged(e)
If (Not (Me.tblBoxRowChangedEvent) Is Nothing) Then
RaiseEvent tblBoxRowChanged(Me, New tblBoxRowChangeEvent(CType(e.Row,tblBoxRow), e.Action))
End If
End Sub

_
Protected Overrides Sub OnRowChanging(ByVal e As Global.System.Data.DataRowChangeEventArgs)
MyBase.OnRowChanging(e)
If (Not (Me.tblBoxRowChangingEvent) Is Nothing) Then
RaiseEvent tblBoxRowChanging(Me, New tblBoxRowChangeEvent(CType(e.Row,tblBoxRow), e.Action))
End If
End Sub

_
Protected Overrides Sub OnRowDeleted(ByVal e As Global.System.Data.DataRowChangeEventArgs)
MyBase.OnRowDeleted(e)
If (Not (Me.tblBoxRowDeletedEvent) Is Nothing) Then
RaiseEvent tblBoxRowDeleted(Me, New tblBoxRowChangeEvent(CType(e.Row,tblBoxRow), e.Action))
End If
End Sub

_
Protected Overrides Sub OnRowDeleting(ByVal e As Global.System.Data.DataRowChangeEventArgs)
MyBase.OnRowDeleting(e)
If (Not (Me.tblBoxRowDeletingEvent) Is Nothing) Then
RaiseEvent tblBoxRowDeleting(Me, New tblBoxRowChangeEvent(CType(e.Row,tblBoxRow), e.Action))
End If
End Sub

_
Public Sub RemovetblBoxRow(ByVal row As tblBoxRow)
Me.Rows.Remove(row)
End Sub

_
Public Shared Function GetTypedTableSchema(ByVal xs As Global.System.Xml.Schema.XmlSchemaSet) As Global.System.Xml.Schema.XmlSchemaComplexType
Dim type As Global.System.Xml.Schema.XmlSchemaComplexType = New Global.System.Xml.Schema.XmlSchemaComplexType()
Dim sequence As Global.System.Xml.Schema.XmlSchemaSequence = New Global.System.Xml.Schema.XmlSchemaSequence()
Dim ds As MusicBoxDataSet = New MusicBoxDataSet()
Dim any1 As Global.System.Xml.Schema.XmlSchemaAny = New Global.System.Xml.Schema.XmlSchemaAny()
any1.Namespace = “http://www.w3.org/2001/XMLSchema”
any1.MinOccurs = New Decimal(0)
any1.MaxOccurs = Decimal.MaxValue
any1.ProcessContents = Global.System.Xml.Schema.XmlSchemaContentProcessing.Lax
sequence.Items.Add(any1)
Dim any2 As Global.System.Xml.Schema.XmlSchemaAny = New Global.System.Xml.Schema.XmlSchemaAny()
any2.Namespace = “urn:schemas-microsoft-com:xml-diffgram-v1”
any2.MinOccurs = New Decimal(1)
any2.ProcessContents = Global.System.Xml.Schema.XmlSchemaContentProcessing.Lax
sequence.Items.Add(any2)
Dim attribute1 As Global.System.Xml.Schema.XmlSchemaAttribute = New Global.System.Xml.Schema.XmlSchemaAttribute()
attribute1.Name = “namespace”
attribute1.FixedValue = ds.Namespace
type.Attributes.Add(attribute1)
Dim attribute2 As Global.System.Xml.Schema.XmlSchemaAttribute = New Global.System.Xml.Schema.XmlSchemaAttribute()
attribute2.Name = “tableTypeName”
attribute2.FixedValue = “tblBoxDataTable”
type.Attributes.Add(attribute2)
type.Particle = sequence
Dim dsSchema As Global.System.Xml.Schema.XmlSchema = ds.GetSchemaSerializable
If xs.Contains(dsSchema.TargetNamespace) Then
Dim s1 As Global.System.IO.MemoryStream = New Global.System.IO.MemoryStream()
Dim s2 As Global.System.IO.MemoryStream = New Global.System.IO.MemoryStream()
Try
Dim schema As Global.System.Xml.Schema.XmlSchema = Nothing
dsSchema.Write(s1)
Dim schemas As Global.System.Collections.IEnumerator = xs.Schemas(dsSchema.TargetNamespace).GetEnumerator
Do While schemas.MoveNext
schema = CType(schemas.Current,Global.System.Xml.Schema.XmlSchema)
s2.SetLength(0)
schema.Write(s2)
If (s1.Length = s2.Length) Then
s1.Position = 0
s2.Position = 0

Do While ((s1.Position <> s1.Length) _
AndAlso (s1.ReadByte = s2.ReadByte))

Loop
If (s1.Position = s1.Length) Then
Return type
End If
End If

Loop
Finally
If (Not (s1) Is Nothing) Then
s1.Close
End If
If (Not (s2) Is Nothing) Then
s2.Close
End If
End Try
End If
xs.Add(dsSchema)
Return type
End Function
End Class

”’

”’Represents strongly named DataRow class.
”’

Partial Public Class tblBoxRow
Inherits Global.System.Data.DataRow

Private tabletblBox As tblBoxDataTable

_
Friend Sub New(ByVal rb As Global.System.Data.DataRowBuilder)
MyBase.New(rb)
Me.tabletblBox = CType(Me.Table,tblBoxDataTable)
End Sub

_
Public Property ID() As String
Get
Return CType(Me(Me.tabletblBox.IDColumn),String)
End Get
Set
Me(Me.tabletblBox.IDColumn) = value
End Set
End Property

_
Public Property Shape() As String
Get
Try
Return CType(Me(Me.tabletblBox.ShapeColumn),String)
Catch e As Global.System.InvalidCastException
Throw New Global.System.Data.StrongTypingException(“The value for column ‘Shape’ in table ‘tblBox’ is DBNull.”, e)
End Try
End Get
Set
Me(Me.tabletblBox.ShapeColumn) = value
End Set
End Property

_
Public Property Source() As String
Get
Try
Return CType(Me(Me.tabletblBox.SourceColumn),String)
Catch e As Global.System.InvalidCastException
Throw New Global.System.Data.StrongTypingException(“The value for column ‘Source’ in table ‘tblBox’ is DBNull.”, e)
End Try
End Get
Set
Me(Me.tabletblBox.SourceColumn) = value
End Set
End Property

_
Public Property Song() As String
Get
Try
Return CType(Me(Me.tabletblBox.SongColumn),String)
Catch e As Global.System.InvalidCastException
Throw New Global.System.Data.StrongTypingException(“The value for column ‘Song’ in table ‘tblBox’ is DBNull.”, e)
End Try
End Get
Set
Me(Me.tabletblBox.SongColumn) = value
End Set
End Property

_
Public Function IsShapeNull() As Boolean
Return Me.IsNull(Me.tabletblBox.ShapeColumn)
End Function

_
Public Sub SetShapeNull()
Me(Me.tabletblBox.ShapeColumn) = Global.System.Convert.DBNull
End Sub

_
Public Function IsSourceNull() As Boolean
Return Me.IsNull(Me.tabletblBox.SourceColumn)
End Function

_
Public Sub SetSourceNull()
Me(Me.tabletblBox.SourceColumn) = Global.System.Convert.DBNull
End Sub

_
Public Function IsSongNull() As Boolean
Return Me.IsNull(Me.tabletblBox.SongColumn)
End Function

_
Public Sub SetSongNull()
Me(Me.tabletblBox.SongColumn) = Global.System.Convert.DBNull
End Sub
End Class

”’

”’Row event argument class
”’

_
Public Class tblBoxRowChangeEvent
Inherits Global.System.EventArgs

Private eventRow As tblBoxRow

Private eventAction As Global.System.Data.DataRowAction

_
Public Sub New(ByVal row As tblBoxRow, ByVal action As Global.System.Data.DataRowAction)
MyBase.New
Me.eventRow = row
Me.eventAction = action
End Sub

_
Public ReadOnly Property Row() As tblBoxRow
Get
Return Me.eventRow
End Get
End Property

_
Public ReadOnly Property Action() As Global.System.Data.DataRowAction
Get
Return Me.eventAction
End Get
End Property
End Class
End Class
Namespace MusicBoxDataSetTableAdapters

”’

”’Represents the connection and commands used to retrieve and save data.
”’

_
Partial Public Class tblBoxTableAdapter
Inherits Global.System.ComponentModel.Component

Private WithEvents _adapter As Global.System.Data.OleDb.OleDbDataAdapter

Private _connection As Global.System.Data.OleDb.OleDbConnection

Private _transaction As Global.System.Data.OleDb.OleDbTransaction

Private _commandCollection() As Global.System.Data.OleDb.OleDbCommand

Private _clearBeforeFill As Boolean

_
Public Sub New()
MyBase.New
Me.ClearBeforeFill = true
End Sub

_
Protected Friend ReadOnly Property Adapter() As Global.System.Data.OleDb.OleDbDataAdapter
Get
If (Me._adapter Is Nothing) Then
Me.InitAdapter
End If
Return Me._adapter
End Get
End Property

_
Friend Property Connection() As Global.System.Data.OleDb.OleDbConnection
Get
If (Me._connection Is Nothing) Then
Me.InitConnection
End If
Return Me._connection
End Get
Set
Me._connection = value
If (Not (Me.Adapter.InsertCommand) Is Nothing) Then
Me.Adapter.InsertCommand.Connection = value
End If
If (Not (Me.Adapter.DeleteCommand) Is Nothing) Then
Me.Adapter.DeleteCommand.Connection = value
End If
If (Not (Me.Adapter.UpdateCommand) Is Nothing) Then
Me.Adapter.UpdateCommand.Connection = value
End If
Dim i As Integer = 0
Do While (i < Me.CommandCollection.Length) If (Not (Me.CommandCollection(i)) Is Nothing) Then CType(Me.CommandCollection(i),Global.System.Data.OleDb.OleDbCommand).Connection = value End If i = (i + 1) Loop End Set End Property _
Friend Property Transaction() As Global.System.Data.OleDb.OleDbTransaction
Get
Return Me._transaction
End Get
Set
Me._transaction = value
Dim i As Integer = 0
Do While (i < Me.CommandCollection.Length) Me.CommandCollection(i).Transaction = Me._transaction i = (i + 1) Loop If ((Not (Me.Adapter) Is Nothing) _ AndAlso (Not (Me.Adapter.DeleteCommand) Is Nothing)) Then Me.Adapter.DeleteCommand.Transaction = Me._transaction End If If ((Not (Me.Adapter) Is Nothing) _ AndAlso (Not (Me.Adapter.InsertCommand) Is Nothing)) Then Me.Adapter.InsertCommand.Transaction = Me._transaction End If If ((Not (Me.Adapter) Is Nothing) _ AndAlso (Not (Me.Adapter.UpdateCommand) Is Nothing)) Then Me.Adapter.UpdateCommand.Transaction = Me._transaction End If End Set End Property _
Protected ReadOnly Property CommandCollection() As Global.System.Data.OleDb.OleDbCommand()
Get
If (Me._commandCollection Is Nothing) Then
Me.InitCommandCollection
End If
Return Me._commandCollection
End Get
End Property

_
Public Property ClearBeforeFill() As Boolean
Get
Return Me._clearBeforeFill
End Get
Set
Me._clearBeforeFill = value
End Set
End Property

_
Private Sub InitAdapter()
Me._adapter = New Global.System.Data.OleDb.OleDbDataAdapter()
Dim tableMapping As Global.System.Data.Common.DataTableMapping = New Global.System.Data.Common.DataTableMapping()
tableMapping.SourceTable = “Table”
tableMapping.DataSetTable = “tblBox”
tableMapping.ColumnMappings.Add(“ID”, “ID”)
tableMapping.ColumnMappings.Add(“Shape”, “Shape”)
tableMapping.ColumnMappings.Add(“Source”, “Source”)
tableMapping.ColumnMappings.Add(“Song”, “Song”)
Me._adapter.TableMappings.Add(tableMapping)
Me._adapter.DeleteCommand = New Global.System.Data.OleDb.OleDbCommand()
Me._adapter.DeleteCommand.Connection = Me.Connection
Me._adapter.DeleteCommand.CommandText = “DELETE FROM `tblBox` WHERE ((`ID` = ?) AND ((? = 1 AND `Shape` IS NULL) OR (`Shap”& _
“e` = ?)) AND ((? = 1 AND `Source` IS NULL) OR (`Source` = ?)) AND ((? = 1 AND `S”& _
“ong` IS NULL) OR (`Song` = ?)))”
Me._adapter.DeleteCommand.CommandType = Global.System.Data.CommandType.Text
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_ID”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “ID”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Shape”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Shape”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Source”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Source”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Song”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.DeleteCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Song”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.InsertCommand = New Global.System.Data.OleDb.OleDbCommand()
Me._adapter.InsertCommand.Connection = Me.Connection
Me._adapter.InsertCommand.CommandText = “INSERT INTO `tblBox` (`ID`, `Shape`, `Source`, `Song`) VALUES (?, ?, ?, ?)”
Me._adapter.InsertCommand.CommandType = Global.System.Data.CommandType.Text
Me._adapter.InsertCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“ID”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “ID”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.InsertCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Shape”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.InsertCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Source”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.InsertCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Song”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.UpdateCommand = New Global.System.Data.OleDb.OleDbCommand()
Me._adapter.UpdateCommand.Connection = Me.Connection
Me._adapter.UpdateCommand.CommandText = “UPDATE `tblBox` SET `ID` = ?, `Shape` = ?, `Source` = ?, `Song` = ? WHERE ((`ID` “& _
“= ?) AND ((? = 1 AND `Shape` IS NULL) OR (`Shape` = ?)) AND ((? = 1 AND `Source`”& _
” IS NULL) OR (`Source` = ?)) AND ((? = 1 AND `Song` IS NULL) OR (`Song` = ?)))”
Me._adapter.UpdateCommand.CommandType = Global.System.Data.CommandType.Text
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“ID”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “ID”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Shape”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Source”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Song”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Current, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_ID”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “ID”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Shape”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Shape”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Shape”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Source”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Source”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Source”, Global.System.Data.DataRowVersion.Original, false, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“IsNull_Song”, Global.System.Data.OleDb.OleDbType.[Integer], 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Original, true, Nothing))
Me._adapter.UpdateCommand.Parameters.Add(New Global.System.Data.OleDb.OleDbParameter(“Original_Song”, Global.System.Data.OleDb.OleDbType.VarWChar, 0, Global.System.Data.ParameterDirection.Input, CType(0,Byte), CType(0,Byte), “Song”, Global.System.Data.DataRowVersion.Original, false, Nothing))
End Sub

_
Private Sub InitConnection()
Me._connection = New Global.System.Data.OleDb.OleDbConnection()
Me._connection.ConnectionString = Global.MusicBox_Project.My.MySettings.Default.MusicBoxConnectionString
End Sub

_
Private Sub InitCommandCollection()
Me._commandCollection = New Global.System.Data.OleDb.OleDbCommand(0) {}
Me._commandCollection(0) = New Global.System.Data.OleDb.OleDbCommand()
Me._commandCollection(0).Connection = Me.Connection
Me._commandCollection(0).CommandText = “SELECT ID, Shape, Source, Song FROM tblBox”
Me._commandCollection(0).CommandType = Global.System.Data.CommandType.Text
End Sub

_
Public Overloads Overridable Function Fill(ByVal dataTable As MusicBoxDataSet.tblBoxDataTable) As Integer
Me.Adapter.SelectCommand = Me.CommandCollection(0)
If (Me.ClearBeforeFill = true) Then
dataTable.Clear
End If
Dim returnValue As Integer = Me.Adapter.Fill(dataTable)
Return returnValue
End Function

_
Public Overloads Overridable Function GetData() As MusicBoxDataSet.tblBoxDataTable
Me.Adapter.SelectCommand = Me.CommandCollection(0)
Dim dataTable As MusicBoxDataSet.tblBoxDataTable = New MusicBoxDataSet.tblBoxDataTable()
Me.Adapter.Fill(dataTable)
Return dataTable
End Function

_
Public Overloads Overridable Function Update(ByVal dataTable As MusicBoxDataSet.tblBoxDataTable) As Integer
Return Me.Adapter.Update(dataTable)
End Function

_
Public Overloads Overridable Function Update(ByVal dataSet As MusicBoxDataSet) As Integer
Return Me.Adapter.Update(dataSet, “tblBox”)
End Function

_
Public Overloads Overridable Function Update(ByVal dataRow As Global.System.Data.DataRow) As Integer
Return Me.Adapter.Update(New Global.System.Data.DataRow() {dataRow})
End Function

_
Public Overloads Overridable Function Update(ByVal dataRows() As Global.System.Data.DataRow) As Integer
Return Me.Adapter.Update(dataRows)
End Function

_
Public Overloads Overridable Function Delete(ByVal Original_ID As String, ByVal Original_Shape As String, ByVal Original_Source As String, ByVal Original_Song As String) As Integer
If (Original_ID Is Nothing) Then
Me.Adapter.DeleteCommand.Parameters(0).Value = Global.System.DBNull.Value
Else
Me.Adapter.DeleteCommand.Parameters(0).Value = CType(Original_ID,String)
End If
If (Original_Shape Is Nothing) Then
Me.Adapter.DeleteCommand.Parameters(1).Value = CType(1,Object)
Me.Adapter.DeleteCommand.Parameters(2).Value = Global.System.DBNull.Value
Else
Me.Adapter.DeleteCommand.Parameters(1).Value = CType(0,Object)
Me.Adapter.DeleteCommand.Parameters(2).Value = CType(Original_Shape,String)
End If
If (Original_Source Is Nothing) Then
Me.Adapter.DeleteCommand.Parameters(3).Value = CType(1,Object)
Me.Adapter.DeleteCommand.Parameters(4).Value = Global.System.DBNull.Value
Else
Me.Adapter.DeleteCommand.Parameters(3).Value = CType(0,Object)
Me.Adapter.DeleteCommand.Parameters(4).Value = CType(Original_Source,String)
End If
If (Original_Song Is Nothing) Then
Me.Adapter.DeleteCommand.Parameters(5).Value = CType(1,Object)
Me.Adapter.DeleteCommand.Parameters(6).Value = Global.System.DBNull.Value
Else
Me.Adapter.DeleteCommand.Parameters(5).Value = CType(0,Object)
Me.Adapter.DeleteCommand.Parameters(6).Value = CType(Original_Song,String)
End If
Dim previousConnectionState As Global.System.Data.ConnectionState = Me.Adapter.DeleteCommand.Connection.State
If ((Me.Adapter.DeleteCommand.Connection.State And Global.System.Data.ConnectionState.Open) _
<> Global.System.Data.ConnectionState.Open) Then
Me.Adapter.DeleteCommand.Connection.Open
End If
Try
Dim returnValue As Integer = Me.Adapter.DeleteCommand.ExecuteNonQuery
Return returnValue
Finally
If (previousConnectionState = Global.System.Data.ConnectionState.Closed) Then
Me.Adapter.DeleteCommand.Connection.Close
End If
End Try
End Function

_
Public Overloads Overridable Function Insert(ByVal ID As String, ByVal Shape As String, ByVal Source As String, ByVal Song As String) As Integer
If (ID Is Nothing) Then
Me.Adapter.InsertCommand.Parameters(0).Value = Global.System.DBNull.Value
Else
Me.Adapter.InsertCommand.Parameters(0).Value = CType(ID,String)
End If
If (Shape Is Nothing) Then
Me.Adapter.InsertCommand.Parameters(1).Value = Global.System.DBNull.Value
Else
Me.Adapter.InsertCommand.Parameters(1).Value = CType(Shape,String)
End If
If (Source Is Nothing) Then
Me.Adapter.InsertCommand.Parameters(2).Value = Global.System.DBNull.Value
Else
Me.Adapter.InsertCommand.Parameters(2).Value = CType(Source,String)
End If
If (Song Is Nothing) Then
Me.Adapter.InsertCommand.Parameters(3).Value = Global.System.DBNull.Value
Else
Me.Adapter.InsertCommand.Parameters(3).Value = CType(Song,String)
End If
Dim previousConnectionState As Global.System.Data.ConnectionState = Me.Adapter.InsertCommand.Connection.State
If ((Me.Adapter.InsertCommand.Connection.State And Global.System.Data.ConnectionState.Open) _
<> Global.System.Data.ConnectionState.Open) Then
Me.Adapter.InsertCommand.Connection.Open
End If
Try
Dim returnValue As Integer = Me.Adapter.InsertCommand.ExecuteNonQuery
Return returnValue
Finally
If (previousConnectionState = Global.System.Data.ConnectionState.Closed) Then
Me.Adapter.InsertCommand.Connection.Close
End If
End Try
End Function

_
Public Overloads Overridable Function Update(ByVal ID As String, ByVal Shape As String, ByVal Source As String, ByVal Song As String, ByVal Original_ID As String, ByVal Original_Shape As String, ByVal Original_Source As String, ByVal Original_Song As String) As Integer
If (ID Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(0).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(0).Value = CType(ID,String)
End If
If (Shape Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(1).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(1).Value = CType(Shape,String)
End If
If (Source Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(2).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(2).Value = CType(Source,String)
End If
If (Song Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(3).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(3).Value = CType(Song,String)
End If
If (Original_ID Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(4).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(4).Value = CType(Original_ID,String)
End If
If (Original_Shape Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(5).Value = CType(1,Object)
Me.Adapter.UpdateCommand.Parameters(6).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(5).Value = CType(0,Object)
Me.Adapter.UpdateCommand.Parameters(6).Value = CType(Original_Shape,String)
End If
If (Original_Source Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(7).Value = CType(1,Object)
Me.Adapter.UpdateCommand.Parameters(8).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(7).Value = CType(0,Object)
Me.Adapter.UpdateCommand.Parameters(8).Value = CType(Original_Source,String)
End If
If (Original_Song Is Nothing) Then
Me.Adapter.UpdateCommand.Parameters(9).Value = CType(1,Object)
Me.Adapter.UpdateCommand.Parameters(10).Value = Global.System.DBNull.Value
Else
Me.Adapter.UpdateCommand.Parameters(9).Value = CType(0,Object)
Me.Adapter.UpdateCommand.Parameters(10).Value = CType(Original_Song,String)
End If
Dim previousConnectionState As Global.System.Data.ConnectionState = Me.Adapter.UpdateCommand.Connection.State
If ((Me.Adapter.UpdateCommand.Connection.State And Global.System.Data.ConnectionState.Open) _
<> Global.System.Data.ConnectionState.Open) Then
Me.Adapter.UpdateCommand.Connection.Open
End If
Try
Dim returnValue As Integer = Me.Adapter.UpdateCommand.ExecuteNonQuery
Return returnValue
Finally
If (previousConnectionState = Global.System.Data.ConnectionState.Closed) Then
Me.Adapter.UpdateCommand.Connection.Close
End If
End Try
End Function

_
Public Overloads Overridable Function Update(ByVal Shape As String, ByVal Source As String, ByVal Song As String, ByVal Original_ID As String, ByVal Original_Shape As String, ByVal Original_Source As String, ByVal Original_Song As String) As Integer
Return Me.Update(Original_ID, Shape, Source, Song, Original_ID, Original_Shape, Original_Source, Original_Song)
End Function
End Class

”’

”’TableAdapterManager is used to coordinate TableAdapters in the dataset to enable Hierarchical Update scenarios
”’

_
Partial Public Class TableAdapterManager
Inherits Global.System.ComponentModel.Component

Private _updateOrder As UpdateOrderOption

Private _tblBoxTableAdapter As tblBoxTableAdapter

Private _backupDataSetBeforeUpdate As Boolean

Private _connection As Global.System.Data.IDbConnection

_
Public Property UpdateOrder() As UpdateOrderOption
Get
Return Me._updateOrder
End Get
Set
Me._updateOrder = value
End Set
End Property

_
Public Property tblBoxTableAdapter() As tblBoxTableAdapter
Get
Return Me._tblBoxTableAdapter
End Get
Set
Me._tblBoxTableAdapter = value
End Set
End Property

_
Public Property BackupDataSetBeforeUpdate() As Boolean
Get
Return Me._backupDataSetBeforeUpdate
End Get
Set
Me._backupDataSetBeforeUpdate = value
End Set
End Property

_
Public Property Connection() As Global.System.Data.IDbConnection
Get
If (Not (Me._connection) Is Nothing) Then
Return Me._connection
End If
If ((Not (Me._tblBoxTableAdapter) Is Nothing) _
AndAlso (Not (Me._tblBoxTableAdapter.Connection) Is Nothing)) Then
Return Me._tblBoxTableAdapter.Connection
End If
Return Nothing
End Get
Set
Me._connection = value
End Set
End Property

_
Public ReadOnly Property TableAdapterInstanceCount() As Integer
Get
Dim count As Integer = 0
If (Not (Me._tblBoxTableAdapter) Is Nothing) Then
count = (count + 1)
End If
Return count
End Get
End Property

”’

”’Update rows in top-down order.
”’

_
Private Function UpdateUpdatedRows(ByVal dataSet As MusicBoxDataSet, ByVal allChangedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow), ByVal allAddedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)) As Integer
Dim result As Integer = 0
If (Not (Me._tblBoxTableAdapter) Is Nothing) Then
Dim updatedRows() As Global.System.Data.DataRow = dataSet.tblBox.Select(Nothing, Nothing, Global.System.Data.DataViewRowState.ModifiedCurrent)
updatedRows = Me.GetRealUpdatedRows(updatedRows, allAddedRows)
If ((Not (updatedRows) Is Nothing) _
AndAlso (0 < updatedRows.Length)) Then result = (result + Me._tblBoxTableAdapter.Update(updatedRows)) allChangedRows.AddRange(updatedRows) End If End If Return result End Function '''

”’Insert rows in top-down order.
”’

_
Private Function UpdateInsertedRows(ByVal dataSet As MusicBoxDataSet, ByVal allAddedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)) As Integer
Dim result As Integer = 0
If (Not (Me._tblBoxTableAdapter) Is Nothing) Then
Dim addedRows() As Global.System.Data.DataRow = dataSet.tblBox.Select(Nothing, Nothing, Global.System.Data.DataViewRowState.Added)
If ((Not (addedRows) Is Nothing) _
AndAlso (0 < addedRows.Length)) Then result = (result + Me._tblBoxTableAdapter.Update(addedRows)) allAddedRows.AddRange(addedRows) End If End If Return result End Function '''

”’Delete rows in bottom-up order.
”’

_
Private Function UpdateDeletedRows(ByVal dataSet As MusicBoxDataSet, ByVal allChangedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)) As Integer
Dim result As Integer = 0
If (Not (Me._tblBoxTableAdapter) Is Nothing) Then
Dim deletedRows() As Global.System.Data.DataRow = dataSet.tblBox.Select(Nothing, Nothing, Global.System.Data.DataViewRowState.Deleted)
If ((Not (deletedRows) Is Nothing) _
AndAlso (0 < deletedRows.Length)) Then result = (result + Me._tblBoxTableAdapter.Update(deletedRows)) allChangedRows.AddRange(deletedRows) End If End If Return result End Function '''

”’Remove inserted rows that become updated rows after calling TableAdapter.Update(inserted rows) first
”’

_
Private Function GetRealUpdatedRows(ByVal updatedRows() As Global.System.Data.DataRow, ByVal allAddedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)) As Global.System.Data.DataRow()
If ((updatedRows Is Nothing) _
OrElse (updatedRows.Length < 1)) Then Return updatedRows End If If ((allAddedRows Is Nothing) _ OrElse (allAddedRows.Count < 1)) Then Return updatedRows End If Dim realUpdatedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow) = New Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)() Dim i As Integer = 0 Do While (i < updatedRows.Length) Dim row As Global.System.Data.DataRow = updatedRows(i) If (allAddedRows.Contains(row) = false) Then realUpdatedRows.Add(row) End If i = (i + 1) Loop Return realUpdatedRows.ToArray End Function '''

”’Update all changes to the dataset.
”’

_
Public Overridable Function UpdateAll(ByVal dataSet As MusicBoxDataSet) As Integer
If (dataSet Is Nothing) Then
Throw New Global.System.ArgumentNullException(“dataSet”)
End If
If (dataSet.HasChanges = false) Then
Return 0
End If
If ((Not (Me._tblBoxTableAdapter) Is Nothing) _
AndAlso (Me.MatchTableAdapterConnection(Me._tblBoxTableAdapter.Connection) = false)) Then
Throw New Global.System.ArgumentException(“All TableAdapters managed by a TableAdapterManager must use the same connection s”& _
“tring.”)
End If
Dim workConnection As Global.System.Data.IDbConnection = Me.Connection
If (workConnection Is Nothing) Then
Throw New Global.System.ApplicationException(“TableAdapterManager contains no connection information. Set each TableAdapterMana”& _
“ger TableAdapter property to a valid TableAdapter instance.”)
End If
Dim workConnOpened As Boolean = false
If ((workConnection.State And Global.System.Data.ConnectionState.Broken) _
= Global.System.Data.ConnectionState.Broken) Then
workConnection.Close
End If
If (workConnection.State = Global.System.Data.ConnectionState.Closed) Then
workConnection.Open
workConnOpened = true
End If
Dim workTransaction As Global.System.Data.IDbTransaction = workConnection.BeginTransaction
If (workTransaction Is Nothing) Then
Throw New Global.System.ApplicationException(“The transaction cannot begin. The current data connection does not support transa”& _
“ctions or the current state is not allowing the transaction to begin.”)
End If
Dim allChangedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow) = New Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)()
Dim allAddedRows As Global.System.Collections.Generic.List(Of Global.System.Data.DataRow) = New Global.System.Collections.Generic.List(Of Global.System.Data.DataRow)()
Dim adaptersWithAcceptChangesDuringUpdate As Global.System.Collections.Generic.List(Of Global.System.Data.Common.DataAdapter) = New Global.System.Collections.Generic.List(Of Global.System.Data.Common.DataAdapter)()
Dim revertConnections As Global.System.Collections.Generic.Dictionary(Of Object, Global.System.Data.IDbConnection) = New Global.System.Collections.Generic.Dictionary(Of Object, Global.System.Data.IDbConnection)()
Dim result As Integer = 0
Dim backupDataSet As Global.System.Data.DataSet = Nothing
If Me.BackupDataSetBeforeUpdate Then
backupDataSet = New Global.System.Data.DataSet()
backupDataSet.Merge(dataSet)
End If
Try
‘—- Prepare for update ———–

If (Not (Me._tblBoxTableAdapter) Is Nothing) Then
revertConnections.Add(Me._tblBoxTableAdapter, Me._tblBoxTableAdapter.Connection)
Me._tblBoxTableAdapter.Connection = CType(workConnection,Global.System.Data.OleDb.OleDbConnection)
Me._tblBoxTableAdapter.Transaction = CType(workTransaction,Global.System.Data.OleDb.OleDbTransaction)
If Me._tblBoxTableAdapter.Adapter.AcceptChangesDuringUpdate Then
Me._tblBoxTableAdapter.Adapter.AcceptChangesDuringUpdate = false
adaptersWithAcceptChangesDuringUpdate.Add(Me._tblBoxTableAdapter.Adapter)
End If
End If

‘—- Perform updates ———–

If (Me.UpdateOrder = UpdateOrderOption.UpdateInsertDelete) Then
result = (result + Me.UpdateUpdatedRows(dataSet, allChangedRows, allAddedRows))
result = (result + Me.UpdateInsertedRows(dataSet, allAddedRows))
Else
result = (result + Me.UpdateInsertedRows(dataSet, allAddedRows))
result = (result + Me.UpdateUpdatedRows(dataSet, allChangedRows, allAddedRows))
End If
result = (result + Me.UpdateDeletedRows(dataSet, allChangedRows))

‘—- Commit updates ———–

workTransaction.Commit
If (0 < allAddedRows.Count) Then Dim rows((allAddedRows.Count) - 1) As Global.System.Data.DataRow allAddedRows.CopyTo(rows) Dim i As Integer = 0 Do While (i < rows.Length) Dim row As Global.System.Data.DataRow = rows(i) row.AcceptChanges i = (i + 1) Loop End If If (0 < allChangedRows.Count) Then Dim rows((allChangedRows.Count) - 1) As Global.System.Data.DataRow allChangedRows.CopyTo(rows) Dim i As Integer = 0 Do While (i < rows.Length) Dim row As Global.System.Data.DataRow = rows(i) row.AcceptChanges i = (i + 1) Loop End If Catch ex As Global.System.Exception workTransaction.Rollback '---- Restore the dataset ----------- If Me.BackupDataSetBeforeUpdate Then Global.System.Diagnostics.Debug.Assert((Not (backupDataSet) Is Nothing)) dataSet.Clear dataSet.Merge(backupDataSet) Else If (0 < allAddedRows.Count) Then Dim rows((allAddedRows.Count) - 1) As Global.System.Data.DataRow allAddedRows.CopyTo(rows) Dim i As Integer = 0 Do While (i < rows.Length) Dim row As Global.System.Data.DataRow = rows(i) row.AcceptChanges row.SetAdded i = (i + 1) Loop End If End If Throw ex Finally If workConnOpened Then workConnection.Close End If If (Not (Me._tblBoxTableAdapter) Is Nothing) Then Me._tblBoxTableAdapter.Connection = CType(revertConnections(Me._tblBoxTableAdapter),Global.System.Data.OleDb.OleDbConnection) Me._tblBoxTableAdapter.Transaction = Nothing End If If (0 < adaptersWithAcceptChangesDuringUpdate.Count) Then Dim adapters((adaptersWithAcceptChangesDuringUpdate.Count) - 1) As Global.System.Data.Common.DataAdapter adaptersWithAcceptChangesDuringUpdate.CopyTo(adapters) Dim i As Integer = 0 Do While (i < adapters.Length) Dim adapter As Global.System.Data.Common.DataAdapter = adapters(i) adapter.AcceptChangesDuringUpdate = true i = (i + 1) Loop End If End Try Return result End Function _
Protected Overridable Sub SortSelfReferenceRows(ByVal rows() As Global.System.Data.DataRow, ByVal relation As Global.System.Data.DataRelation, ByVal childFirst As Boolean)
Global.System.Array.Sort(Of Global.System.Data.DataRow)(rows, New SelfReferenceComparer(relation, childFirst))
End Sub

_
Protected Overridable Function MatchTableAdapterConnection(ByVal inputConnection As Global.System.Data.IDbConnection) As Boolean
If (Not (Me._connection) Is Nothing) Then
Return true
End If
If ((Me.Connection Is Nothing) _
OrElse (inputConnection Is Nothing)) Then
Return true
End If
If String.Equals(Me.Connection.ConnectionString, inputConnection.ConnectionString, Global.System.StringComparison.Ordinal) Then
Return true
End If
Return false
End Function

”’

”’Update Order Option
”’

_
Public Enum UpdateOrderOption

InsertUpdateDelete = 0

UpdateInsertDelete = 1
End Enum

”’

”’Used to sort self-referenced table’s rows
”’

_
Private Class SelfReferenceComparer
Inherits Object
Implements Global.System.Collections.Generic.IComparer(Of Global.System.Data.DataRow)

Private _relation As Global.System.Data.DataRelation

Private _childFirst As Integer

_
Friend Sub New(ByVal relation As Global.System.Data.DataRelation, ByVal childFirst As Boolean)
MyBase.New
Me._relation = relation
If childFirst Then
Me._childFirst = -1
Else
Me._childFirst = 1
End If
End Sub

_
Private Function GetRoot(ByVal row As Global.System.Data.DataRow, ByRef distance As Integer) As Global.System.Data.DataRow
Global.System.Diagnostics.Debug.Assert((Not (row) Is Nothing))
Dim root As Global.System.Data.DataRow = row
distance = 0
Dim traversedRows As Global.System.Collections.Generic.IDictionary(Of Global.System.Data.DataRow, Global.System.Data.DataRow) = New Global.System.Collections.Generic.Dictionary(Of Global.System.Data.DataRow, Global.System.Data.DataRow)()
traversedRows(row) = row
Dim parent As Global.System.Data.DataRow = row.GetParentRow(Me._relation, Global.System.Data.DataRowVersion.[Default])
Do While ((Not (parent) Is Nothing) _
AndAlso (traversedRows.ContainsKey(parent) = false))
distance = (distance + 1)
root = parent
traversedRows(parent) = parent
parent = parent.GetParentRow(Me._relation, Global.System.Data.DataRowVersion.[Default])
Loop
If (distance = 0) Then
traversedRows.Clear
traversedRows(row) = row
parent = row.GetParentRow(Me._relation, Global.System.Data.DataRowVersion.Original)
Do While ((Not (parent) Is Nothing) _
AndAlso (traversedRows.ContainsKey(parent) = false))
distance = (distance + 1)
root = parent
traversedRows(parent) = parent
parent = parent.GetParentRow(Me._relation, Global.System.Data.DataRowVersion.Original)
Loop
End If
Return root
End Function

_
Public Function Compare(ByVal row1 As Global.System.Data.DataRow, ByVal row2 As Global.System.Data.DataRow) As Integer Implements Global.System.Collections.Generic.IComparer(Of Global.System.Data.DataRow).Compare
If Object.ReferenceEquals(row1, row2) Then
Return 0
End If
If (row1 Is Nothing) Then
Return -1
End If
If (row2 Is Nothing) Then
Return 1
End If
Dim distance1 As Integer = 0
Dim root1 As Global.System.Data.DataRow = Me.GetRoot(row1, distance1)
Dim distance2 As Integer = 0
Dim root2 As Global.System.Data.DataRow = Me.GetRoot(row2, distance2)
If Object.ReferenceEquals(root1, root2) Then
Return (Me._childFirst * distance1.CompareTo(distance2))
Else
Global.System.Diagnostics.Debug.Assert(((Not (root1.Table) Is Nothing) _
AndAlso (Not (root2.Table) Is Nothing)))
If (root1.Table.Rows.IndexOf(root1) < root2.Table.Rows.IndexOf(root2)) Then Return -1 Else Return 1 End If End If End Function End Class End Class End Namespace MusicBox Solution-LINQ/MusicBox Project/MusicBoxDataSet.xsc MusicBox Solution-LINQ/MusicBox Project/MusicBoxDataSet.xsd DELETE FROM `tblBox` WHERE ((`ID` = ?) AND ((? = 1 AND `Shape` IS NULL) OR (`Shape` = ?)) AND ((? = 1 AND `Source` IS NULL) OR (`Source` = ?)) AND ((? = 1 AND `Song` IS NULL) OR (`Song` = ?))) INSERT INTO `tblBox` (`ID`, `Shape`, `Source`, `Song`) VALUES (?, ?, ?, ?) SELECT ID, Shape, Source, Song FROM tblBox UPDATE `tblBox` SET `ID` = ?, `Shape` = ?, `Source` = ?, `Song` = ? WHERE ((`ID` = ?) AND ((? = 1 AND `Shape` IS NULL) OR (`Shape` = ?)) AND ((? = 1 AND `Source` IS NULL) OR (`Source` = ?)) AND ((? = 1 AND `Song` IS NULL) OR (`Song` = ?))) MusicBox Solution-LINQ/MusicBox Project/MusicBoxDataSet.xss MusicBox Solution-LINQ/MusicBox Project/My Project/Application.Designer.vb '------------------------------------------------------------------------------ '
‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My

‘NOTE: This file is auto-generated; do not modify it directly. To make changes,
‘ or if you encounter build errors in this file, go to the Project Designer
‘ (go to Project Properties or double-click the My Project node in
‘ Solution Explorer), and make changes on the Application tab.

Partial Friend Class MyApplication

_
Public Sub New()
MyBase.New(Global.Microsoft.VisualBasic.ApplicationServices.AuthenticationMode.Windows)
Me.IsSingleInstance = false
Me.EnableVisualStyles = true
Me.SaveMySettingsOnExit = true
Me.ShutDownStyle = Global.Microsoft.VisualBasic.ApplicationServices.ShutdownMode.AfterMainFormCloses
End Sub

_
Protected Overrides Sub OnCreateMainForm()
Me.MainForm = Global.MusicBox_Project.frmMain
End Sub
End Class
End Namespace

MusicBox Solution-LINQ/MusicBox Project/My Project/Application.myapp


true
frmMain
false
0
true
0
true

MusicBox Solution-LINQ/MusicBox Project/My Project/AssemblyInfo.vb
Imports System
Imports System.Reflection
Imports System.Runtime.InteropServices
‘ General Information about an assembly is controlled through the following
‘ set of attributes. Change these attribute values to modify the information
‘ associated with an assembly.
‘ Review the values of the assembly attributes







‘The following GUID is for the ID of the typelib if this project is exposed to COM

‘ Version information for an assembly consists of the following four values:

‘ Major Version
‘ Minor Version
‘ Build Number
‘ Revision

‘ You can specify all the values or you can default the Build and Revision Numbers
‘ by using the ‘*’ as shown below:


MusicBox Solution-LINQ/MusicBox Project/My Project/Resources.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My.Resources

‘This class was auto-generated by the StronglyTypedResourceBuilder
‘class via a tool like ResGen or Visual Studio.
‘To add or remove a member, edit your .ResX file then rerun ResGen
‘with the /str option, or rebuild your VS project.
”’

”’ A strongly-typed resource class, for looking up localized strings, etc.
”’

_
Friend Module Resources
Private resourceMan As Global.System.Resources.ResourceManager
Private resourceCulture As Global.System.Globalization.CultureInfo
”’

”’ Returns the cached ResourceManager instance used by this class.
”’

_
Friend ReadOnly Property ResourceManager() As Global.System.Resources.ResourceManager
Get
If Object.ReferenceEquals(resourceMan, Nothing) Then
Dim temp As Global.System.Resources.ResourceManager = New Global.System.Resources.ResourceManager(“MusicBox_Project.Resources”, GetType(Resources).Assembly)
resourceMan = temp
End If
Return resourceMan
End Get
End Property
”’

”’ Overrides the current thread’s CurrentUICulture property for all
”’ resource lookups using this strongly typed resource class.
”’

_
Friend Property Culture() As Global.System.Globalization.CultureInfo
Get
Return resourceCulture
End Get
Set(ByVal value As Global.System.Globalization.CultureInfo)
resourceCulture = value
End Set
End Property
End Module
End Namespace

MusicBox Solution-LINQ/MusicBox Project/My Project/Resources.resx

text/microsoft-resx

2.0

System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

MusicBox Solution-LINQ/MusicBox Project/My Project/Settings.Designer.vb
‘——————————————————————————

‘ This code was generated by a tool.
‘ Runtime Version:4.0.30319.18010

‘ Changes to this file may cause incorrect behavior and will be lost if
‘ the code is regenerated.

‘——————————————————————————
Option Strict On
Option Explicit On

Namespace My

_
Partial Friend NotInheritable Class MySettings
Inherits Global.System.Configuration.ApplicationSettingsBase

Private Shared defaultInstance As MySettings = CType(Global.System.Configuration.ApplicationSettingsBase.Synchronized(New MySettings()),MySettings)

#Region “My.Settings Auto-Save Functionality”
#If _MyType = “WindowsForms” Then
Private Shared addedHandler As Boolean
Private Shared addedHandlerLockObject As New Object
_
Private Shared Sub AutoSaveSettings(ByVal sender As Global.System.Object, ByVal e As Global.System.EventArgs)
If My.Application.SaveMySettingsOnExit Then
My.Settings.Save()
End If
End Sub
#End If
#End Region

Public Shared ReadOnly Property [Default]() As MySettings
Get

#If _MyType = “WindowsForms” Then
If Not addedHandler Then
SyncLock addedHandlerLockObject
If Not addedHandler Then
AddHandler My.Application.Shutdown, AddressOf AutoSaveSettings
addedHandler = True
End If
End SyncLock
End If
#End If
Return defaultInstance
End Get
End Property

_
Public ReadOnly Property MusicBoxConnectionString() As String
Get
Return CType(Me(“MusicBoxConnectionString”),String)
End Get
End Property
End Class
End Namespace
Namespace My

_
Friend Module MySettingsProperty

_
Friend ReadOnly Property Settings() As Global.MusicBox_Project.My.MySettings
Get
Return Global.MusicBox_Project.My.MySettings.Default
End Get
End Property
End Module
End Namespace

MusicBox Solution-LINQ/MusicBox Project/My Project/Settings.settings



Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\MusicBox.accdb
System.Data.OleDb

Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\MusicBox.accdb

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/DesignTimeResolveAssemblyReferences.cache

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox Project.exe

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox Project.pdb

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox Project.vbproj.FileListAbsolute.txt
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\bin\Debug\MusicBox Project.exe.config
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\bin\Debug\MusicBox.accdb
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\bin\Debug\MusicBox Project.exe
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\bin\Debug\MusicBox Project.pdb
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\bin\Debug\MusicBox Project.xml
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox_Project.frmMain.resources
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox_Project.Resources.resources
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox Project.vbproj.GenerateResource.Cache
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox Project.exe
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox Project.xml
C:\Users\droeb_000\Dropbox\Classes\_CST-271\StudentDataFiles\Chap13\MusicBox Solution-LINQ\MusicBox Project\obj\Debug\MusicBox Project.pdb

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox Project.vbproj.GenerateResource.Cache

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox Project.xml

MusicBoxProject

Represents the strongly named DataTable class.

Represents strongly named DataRow class.

Row event argument class

Represents a strongly typed in-memory cache of data.

Represents the connection and commands used to retrieve and save data.

Update rows in top-down order.

Insert rows in top-down order.

Delete rows in bottom-up order.

Remove inserted rows that become updated rows after calling TableAdapter.Update(inserted rows) first

Update all changes to the dataset.

Update Order Option

Used to sort self-referenced table’s rows

TableAdapterManager is used to coordinate TableAdapters in the dataset to enable Hierarchical Update scenarios

Returns the cached ResourceManager instance used by this class.

Overrides the current thread’s CurrentUICulture property for all
resource lookups using this strongly typed resource class.

A strongly-typed resource class, for looking up localized strings, etc.

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox_Project.frmMain.resources

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/MusicBox_Project.Resources.resources

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/TempPE/MusicBoxDataSet.Designer.vb.dll

MusicBox Solution-LINQ/MusicBox Project/obj/Debug/TempPE/My Project.Resources.Designer.vb.dll

MusicBox Solution-LINQ/MusicBox Solution.sln

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio 2012
Project(“{F184B08F-C81C-45F6-A57F-5ABD9991F28F}”) = “MusicBox Project”, “MusicBox Project\MusicBox Project.vbproj”, “{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}”
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Release|Any CPU = Release|Any CPU
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}.Debug|Any CPU.Build.0 = Debug|Any CPU
{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}.Release|Any CPU.ActiveCfg = Release|Any CPU
{882F8DAA-66E2-40D5-99E4-EE043CB3F1AD}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
EndGlobal

MusicBox Solution-LINQ/MusicBox Solution.v11.suo

Still stressed from student homework?
Get quality assistance from academic writers!

Order your essay today and save 25% with the discount code LAVENDER