Title: ADO.NET 2.0
1ADO.NET 2.0
CaptatorTlf 8620 4242www.captator.dkHenrik
Lykke NielsenSoftwarearkitekt, Microsoft
Regional Director for Denmarklykke_at_captator.dkMo
bil 2237 3311
2Agenda
- Providermodellen
- Basis klasser og interfaces
- Provider factories, Connectionstrenge
- Schema API
- DataSet, DataTable, DataView
- Indexeringsmekanisme, serialisering
- SqlBulkCopy
- Asynkrone kald
- DataBinding
3ADO.NET arkitekturen
VS.NET Designers
.NET Data Provider
DataSet
DataAdapter
DataReader
Item
Command
Order
Connection
ltxmlgtlt/xmlgt
4Basis klasser og interfaces i 1.1
Bemærk Læses som at SqlDataAdapter arver fra
DbDataAdapter
- OleDb
- OleDbConnection
- IDbConnection
- OleDbCommand
- IDbCommand
- OleDbDataAdapter
- DbDataAdapter
- DataAdapter
- IDataAdapter
- IDbDataAdapter
- IDataAdapter
- OleDbDataReader
- IDataReader
- IDataRecord
- SqlClient
- SqlConnection
- IDbConnection
- SqlCommand
- IDbCommand
- SqlDataAdapter
- DbDataAdapter
- DataAdapter
- IDataAdapter
- IDbDataAdapter
- IDataAdapter
- SqlDataReader
- IDataReader
- IDataRecord
5Basis klasser og interfaces i 2.0
- OleDb
- OleDbConnection
- DbConnection
- IDbConnection
- OleDbCommand
- DbCommand
- IDbCommand
- OleDbDataAdapter
- DbDataAdapter
- DataAdapter
- IDataAdapter
- IDbDataAdapter
- IDataAdapter
- OleDbDataReader
- SqlClient
- SqlConnection
- DbConnection
- IDbConnection
- ISqlConnection
- IDbConnection
- SqlCommand
- DbCommand
- IDbCommand
- ISqlCommand
- IDbCommand
- SqlDataAdapter
- DbDataAdapter
- DataAdapter
- IDataAdapter
- IDbDataAdapter
- IDataAdapter
- SqlDataReader
DbDataAdapter implementerer nu IDbDataAdapter
6Interfaces og basis klasse i 1.1
SqlClient klasse OleDb klasse Basisklasse/interface
SqlConnection OleDbConnection IDbConnection
SqlCommand OleDbCommand IDbCommand
SqlDataReader OleDbDataReader IDataReader IDataRecord
SqlTransaction OleDbTransaction IDbTransaction
SqlParameter OleDbParameter IDbDataParameter IDataParameter
SqlParameterCollection OleDbParameterCollection IDataParameterCollection IList
SqlDataAdapter OleDbDataAdapter DbDataAdapter DataAdapter IDbDataAdapter IDataAdapter
SqlCommandBuilder OleDbCommandBuilder
SqlException SystemException OleDbException ExternalException SystemException
7Interfaces og basis klasser i 2.0
- De abstrakte basis klasser befinder sig i
System.Data.Common namespacet
SqlClient klasse Abstrakt basis klasse Interface
SqlConnection DbConnection IDbConnection
SqlCommand DbCommand IDbCommand
SqlDataReader DbDataReader IDataReader IDataRecord
SqlTransaction DbTransaction IDbTransaction
SqlParameter DbParameter IDbDataParameter IDataParameter
SqlParameterCollection DbParameterCollection IDataParameterCollection IList
SqlDataAdapter DbDataAdapter IDbDataAdapter IDataAdapter
SqlCommandBuilder DbCommandBuilder
SqlException DbException
SqlConnectionStringBuilder DbConnectionStringBuilder
8Provider factories
- System.Data.Common.DbProviderFactory
- En abstrakt klasse der er basisklasse for de
konkrete factories SqlClientFactory,
OleDbFactory, ... - Metoder
- CreateConnection As DbConnection
- CreateCommand As DbCommand
- CreateCommandBuilder, CreateConnectionStringBuilde
r, CreateDataAdapter, CreateParameter,
CreatePermission, CreateDataSourceEnumerator,
CanCreateDataSourceEnumerator - De konkrete factories har ingen konstruktører,
men i stedet en Instance-metode
VB
Public ReadOnly Shared Instance As
SqlClientFactory
public readonly static SqlClientFactory Instance
C
9Provider factories
- System.Data.Common.DbProviderFactories
- Util klasse
- Metoder
Public Shared Function GetFactory(ByVal
providerInvariantName As String) _ As
System.Data.Common.DbProviderFactory Public
Shared Function GetFactory(ByVal providerRow As
System.Data.DataRow) _ As System.Data.Common.D
bProviderFactory Public Shared Function
GetFactoryClasses() As System.Data.DataTable
VB
public static System.Data.Common.DbProviderFactory
GetFactory( string providerInvariantName) pu
blic static System.Data.Common.DbProviderFactory
GetFactory( System.Data.DataRow
providerRow) public static System.Data.DataTable
GetFactoryClasses()
C
10Provider factories
- DbProviderFactories er registreret i
machine.config - GetFactoryClasses
- giver en DataTable
- med ovenstående
- info
ltsystem.datagt ltDbProviderFactoriesgt ltadd
name"Odbc Data Provider"
invariant"System.Data.Odbc"
support"BF" description".Net Framework
Data Provider for Odbc"
type"System.Data.Odbc.OdbcFactory, System.Data,
Version2.0.0.0, Cultureneutral,
PublicKeyTokenb77a5c561934e089" /gt ltadd
name"OleDb Data Provider" ... /gt ltadd
name"OracleClient Data Provider" ... /gt ltadd
name"SqlClient Data Provider" ... /gt ltadd
name"SQL Server CE Data Provider" ... /gt
lt/DbProviderFactoriesgt lt/system.datagt
Attibut-navn Column-navn
name Name
invariant InvariantName
support SupportedClasses
description Description
type AssemblyQualifiedName
11ConnectionStrenge
- System.Data.Common.DbConnectionStringBuilderer
et svagt-typet dictionary
Dim factory As System.Data.Common.DbProviderFactor
y factory DbProviderFactories.GetFactory("System
.Data.SqlClient") Dim connBuilder As
System.Data.Common.DbConnectionStringBuilder connB
uilder factory.CreateConnectionStringBuilder()
connBuilder.Add("Data Source", "localhost") connBu
ilder.Add("User Id", "DemoUser") connBuilder.Add("
Password", "hemmeligt")
VB
System.Data.Common.DbProviderFactory
factory factory DbProviderFactories.GetFactory(
"System.Data.SqlClient") System.Data.Common.DbCo
nnectionStringBuilder connBuilder connBuilder
factory.CreateConnectionStringBuilder() connBuil
der.Add("Data Source", "localhost") connBuilder.A
dd("User Id", "DemoUser") connBuilder.Add("Passwo
rd", "hemmeligt")
C
12ConnectionStrenge
- Nedarves af (mere eller mindre) typestærke
klasser - OdbcConnectionStringBuilder
- Driver, Dsn
- OleDbConnectionStringBuilder
- DataSource, FileName, Provider, ...
- OracleClientConnectionStringBuilder
- DataSource, IntegratedSecurity,
LoadBalanceTimeout, MaxPoolSize, MinPoolSize,
Password, PersistSecurityInfo, Pooling, Unicode,
UserID, ... - SqlConnectionStringBuilder
- ApplicationName, AsynchronousProcessing,
ConnectTimeout, DataSource, Encrypt,
FailOverPartner, InitialCatalog,
IntegratedSecurity, LoadBalanceTimeout,
MaxPoolSize, MinPoolSize, MultipleActiveResultSets
, NetworkLibrary, Password, PersistSecurityInfo,
Pooling, Replication, UserID, ...
13Enumerering af data sources
- GetDataSources på en DbDataSourceEnumerator
finder datasources (MS SQL) på nettet - System.Data.Sql.SqlDataSourceEnumerator er den
eneste konkrete implementation
Dim factory As System.Data.Common.DbProviderFactor
y factory DbProviderFactories.GetFactory("System
.Data.SqlClient") Dim enumerator As
System.Data.Common.DbDataSourceEnumerator enumerat
or factory.CreateDataSourceEnumerator() Dim
dataSourceTable As System.Data.DataTable
enumerator.GetDataSources()
VB
System.Data.Common.DbProviderFactory
factory factory DbProviderFactories.GetFactory(
"System.Data.SqlClient") System.Data.Common.DbDa
taSourceEnumerator enumerator enumerator
factory.CreateDataSourceEnumerator() System.Data
.DataTable dataSourceTable enumerator.GetDataSou
rces()
C
14Fælles programmeringsmodel
- Lettere for Microsoft (og andre) at udvide
providere - Mere ensartet programmeringsmodel
- Provider factories løser instansieringsproblemet
- Gem providerens InvariantName i f.eks.
konfiguationsfil - GetFactory der returnerer den enkelte provider
factory instans bruger reflektion så genbrug
den! - Brug af basisklasser giver ikke performance
overhead - GetFactoryClasses() god til udvikler/admin tools
- ConnectionStringBuilders gør det lettere at lave
connectionstrenge men de enkelte er (desværre)
ret forskellige
15Schema APIet
- API til at få schema-oplysninger om en DataSource
- DbConnections GetSchema-metode i tre former
Public Function conn.GetSchema() As
DataTable Public Function conn.GetSchema(collecti
onName As String) As DataTable Public Function
conn.GetSchema(collectionName As String, _
restrictionValues As String()) As DataTable
VB
public DataTable conn.GetSchema() public
DataTable conn.GetSchema(string
collectionName) public DataTable
conn.GetSchema(string collectionName, string
restrictionValues)
C
16Schema - MetaDataCollections
- Få en liste over metadatacollections
- Metadata collections
- MetaDataCollections, DataSourceInformation,
DataTypes, Restrictions, Users, Databases,
Tables, Columns, Views, ViewColumns,
ProcedureParameters, Procedures, ForeignKeys,
IndexColumns, Indexes, UserDefinesTypes
VB
Dim tbl As DataTable conn.GetSchema() '
eller tbl conn.GetSchema("MetaDataCollections")
DataTable tbl conn.GetSchema() //
eller DataTable tbl conn.GetSchema("MetaDataColl
ections")
C
17Schema - DataSourceInformation
- Få informationer om datasourcen
- Indeholder én row
- Muligvis forskellige felter ens for MSs
providere - DataSourceProductName, DataSourceProductVersion,
IdentifierPattern, ParameterMarkerFormat,
ParameterMarkerPattern, ParameterNameMaxLength,
ParameterNamePattern, QuotedIdentifierPattern,
StatementSeparatorPattern, StringLiteralPattern,
SupportedJoinOperators, ...
VB
Dim tbl As DataTable conn.GetSchema("DataSourceI
nformation")
DataTable tbl conn.GetSchema("DataSourceInformat
ion")
C
18Schema - restriktioner
- Restriktioner er simple filtre for, hvilke
entiteter man ønsker metadata for - Restriktioner angives via værdier i et streng
array - Restriktioner er defineret i Restrictions-collec
tionen - Eksempel på brug af restrictioner
- Konkrete informationer varierer mellem providere
Dim res As String(3) res(1) "Person" res(2)
"Contact" Dim tbl As System.Data.DataTable
conn.GetSchema("Columns", res)
VB
string res new string4 res1 "Person"
res2 "Contact" System.Data.DataTable tbl
conn.GetSchema("Columns", res)
C
19DataSet, DataTable - performance
- Ny indexeringsmekanisme giver markant forbedret
performance ved for eksempel Fill og Merge
public System.Data.DataTable CreateDataTable(int
numberOfRows) System.Random rnd new
System.Random() System.Data.DataTable tbl
new System.Data.DataTable()
tbl.Columns.Add("Id", typeof(System.Guid))
tbl.Columns"Id".Unique true
tbl.Columns.Add("RandomValue", typeof(int))
for (int n 0 n lt numberOfRows n)
System.Data.DataRow row tbl.NewRow()
row"Id" System.Guid.NewGuid()
row"RandomValue" rnd.Next()
tbl.Rows.Add(row) return tbl
C
20DataSet, DataTable - performance
Antal rows VS2003ikke unique VS2005ikke unique VS2003 unique VS2005 unique
100.000 1 sek 1 sek 6 sek 3 sek
200.000 1 sek 2 sek 33 sek 6 sek
500.000 3 sek 5 sek 322 sek 17 sek
1.000.000 6 sek 11 sek 1414 sek 38 sek
21Dataset, DataTable - serialisering
- DataSets og DataTables serialiserer sig selv som
XML uanset man bruger en BinaryFormatter - Kan nu fortælle, at der skal serialiseres binært
- RemotingFormat-propertyen kan sættes til
- System.Data.SerializationFormat.Xml (default)
- System.Data.SerializationFormat.Binary
22Dataset, DataTable - serialisering
tbl.RemotingFormat System.Data.SerializationForm
at.Binary Dim formatter As New
BinaryFormatter() Dim st As New
FileStream(fileName, FileMode.Create) formatter.Se
rialize(st, tbl) st.Close()
- Eksempel med 100.000 simple rows skrevet til fil
- XML-format 16.813 KB 19.851 KB
- Binært format 835 KB 3.374 KB
VB
tbl.RemotingFormat System.Data.SerializationForm
at.Binary BinaryFormatter formatter new
BinaryFormatter() FileStream st new
FileStream(fileName, FileMode.Create) formatter.S
erialize(st, tbl) st.Close()
C
23DataTable - XML
- XML understøttelse som for DataSetsReadXml,
ReadXmlSchemaWriteXml, WriteXmlSchema
24DataSet, DataTable, DataReader
- Populér DataTable/DataSet ud fra DataReader
- Generer DataReader ud fra DataTable/DataSet
- Hvis CreateDataReader kaldes på et DataSet med
flere tabeller vil DataReaderen indeholde
multiple resultset
' Tag fat i en database Dim dr As
System.Data.SqlClient.SqlDataReader
cmd.ExecuteReader() Dim tbl As New
System.Data.DataTable() tbl.Load(dr)
VB
// Tag fat i en database System.Data.SqlClient.S
qlDataReader dr cmd.ExecuteReader() System.Data
.DataTable tbl new System.Data.DataTable() tbl.
Load(dr)
C
VB
Dim tbl As System.Data.DataTable
LavEnDataTable() Dim dr As System.Data.DataTableRe
ader tbl.CreateDataReader()
System.Data.DataTable tbl LavEnDataTable() Syst
em.Data.DataTableReader dr tbl.CreateDataReader(
)
C
25DataTable, DataView
- Generer en DataTable ud fra et DataView
Dim tbl As System.Data.DataTable
LavEnDataTable() Dim view As New
System.Data.DataView(tbl) view.Sort "FirstName
ASC, LastName DESC" view.RowFilter
"FirstNamegt'C'" Dim columnNames As String()
"FirstName", "LastName" Dim tblFiltered As
System.Data.DataTabletblFiltered
view.ToTable("MinFiltreredeTabel", False,
columnNames)
VB
System.Data.DataTable tbl LavEnDataTable() Sys
tem.Data.DataView view new System.Data.DataView(
tbl) view.Sort "FirstName ASC, LastName
DESC" view.RowFilter "FirstNamegt'C'" string
columnNames "FirstName", "LastName"
System.Data.DataTable tblFilteredtblFiltered
view.ToTable("MinFiltreredeTabel", false,
columnNames)
C
26Connection statistik - SqlClient
- StatisticsEnabled, RetrieveStatistics
conn.StatisticsEnabled true System.Collections
.Hashtable statistics (System.Collections.Ha
shtable)_conn.RetrieveStatistics() txtStatistics
.Text "" foreach (string key in
statistics.Keys) txtStatistics.Text
key.PadRight(20, ' ') " " statisticskey.ToS
tring() "\r\n"
C
NetworkServerTime 50 BytesReceived
20989728 UnpreparedExecs 12 SumResultSets
12 SelectCount 12 PreparedExecs
0 ConnectionTime 113202 ExecutionTime
3194 Prepares 0
BuffersSent 12 SelectRows
239664 ServerRoundtrips 12 CursorOpens
0 Transactions 0 BytesSent
1968 BuffersReceived 2628 IduRows
0 IduCount 0
27Multiple Active ResultSets (MARS)
- SQL Server 2005 feature
- Man kan nu have flere resultsets åbne på samme
tid flere DataReadere om en connection (hver sin
command)
SqlClient.SqlConnection conn new
SqlClient.SqlConnection(connString) conn.Open()
SqlClient.SqlCommand cmd1 new
SqlClient.SqlCommand(sql1, conn) SqlClient.SqlDat
aReader rd1 cmd1.ExecuteReader() rd1.Read()
rd1.Read() rd1.Read() rd1.Read() rd1.Read()
rd1.Read() SqlClient.SqlCommand cmd2 new
SqlClient.SqlCommand(sql2, conn) SqlClient.SqlDat
aReader rd2 cmd2.ExecuteReader() rd2.Read()
rd1.Read() rd2.Read() rd2.Close() rd1.Close()
conn.Close()
C
Op til 9 poolede commands per connection
28UpdateBatchSize og SqlBulkCopy
- DbDataAdapter.UpdateBatchSize property påvirker
DbDataAdapter.Update - System.Data.SqlClient.SqlBulkCopy påvirker
performance - 100.000 rows i en DataTable
- DbDataAdapter.Update tog 70 sekunder
(BatchSize100) - SqlBulkCopy.WriteToServer tog 3 sekunder
System.Data.DataTable tbl CreateDataTable(100000
) System.Data.SqlClient.SqlBulkCopy bulk
new System.Data.SqlClient.SqlBulkCopy(connString)
bulk.DestinationTableName "RandomTable" bulk.
WriteToServer(tbl) bulk.Close()
C
29Asynkrone kald
- Asynkrone kommandoer i ADO.NET 1.1 og ADO.NET
2.0 - I 1.1 er det muligt at lave asynkrone kald ved at
bruge ThreadPool eller asynkrone delegates en
baggrundstråd blokeres - Asynkrone kommandoer i 2.0 blokerer ingen
baggrundstråde - Brugen af asynkrone kommandoer til ADO.NET
(SqlClient) - I scenarier hvor det er vigtigt ikke at blokere
tråde (fx. Web apps) - Designet som resten af de asynkrone arkitekturer
i .NET - Xxx gt BeginXxx med input-parms og EndXxx med
output-parms og retur-værdi
Synkron Metode Asynkrone Metoder Asynkrone Metoder
Synkron Metode BeginXxx EndXxx
ExecuteNonQuery BeginExecuteNonQuery EndExecuteNonQuery
ExecuteReader BeginExecuteReader EndExecuteReader
ExecuteXmlReader BeginExecuteXmlReader EndExecuteXmlReader
30Asynkrone kald
- Opsætning
- Asynchronous Processingtrue eller asynctrue
i Connectionstring - Brug forskellige connections til synkrone og
asynkrone connections (af hensyn til performance) - Der findes 4 måder at afslutte et asynkront kald
på - Callback angiv metode der skal kaldes når
arbejde udført - Synkroniseringsobjekt koordinering af asynkrone
kald via WaitHandle - Polling check på IAsyncResults property
IsCompleted - Kald EndXxx som vil blokere indtil det asynkrone
kald er færdigt - Vær opmærksom på
- Kald EndXxx, når et asynkront kald er færdigt
(for at undgå ressource-leaks) - Der kan kastes exceptions ved både BeginXxx og
EndXxx
31DataBinding
- System.Windows.Forms.BindingSource fungerer
- som en datakilde for kontroller
- som en mekanisme for opdatering af data
- som et datalager (datasource) i sig selv
- Kan bindes til forskellige datasources
- Simple objekter (benytter properties)
- Lister såsom ArrayList
- Komplekse datakilder såsom DataTables
32DataBinding
- Sæt BindingSources DataSource-property til
datakilden - DataSource kan også sættes til en System.Type
- Informationen videregives til kontroller der
bindes
Dim binding As System.Windows.Forms.BindingSource
binding New System.Windows.Forms.BindingSource(
) grdPerson.DataSource binding Dim p As
Person p New Person("Mr", "Anders", "And",
"a.and_at_andeby.com") binding.Add(p) p New
Person("Ms", "Andersine", "And",
"a2.and_at_andeby.com") binding.Add(p) p New
Person("Mr", "Mikkel", "Mus", "m.mus_at_andeby.com")
binding.Add(p)
VB
33DataBinding
- Events såsom
- AddingNew, CurrentItemChanged, PositionChanged
- ListChanged(ListChangedType Added, Changed,
Removed, Moved, ...) - Properties såsom
- Current, Filter, Position, Sort, ListCount
- Metoder såsom
- Move, Add, Clear, Remove, RemoveFIlter,
RemoveSort - ResetBindings-metoden fortæller kontrollerne, at
data har ændret sig
34DataBinding- BindingNavigator
- En video kontrol der kan bruges til navigering og
redigering - Sæt BindingNavigator-komponentens
BindingSource-property til et BindingSource
objekt - ToolStripButtons kan let tilføjes og fjernes
35Spørgsmål
www.captator.dknyheder, artikler, information,
...