ADO.NET 2.0 - PowerPoint PPT Presentation

About This Presentation
Title:

ADO.NET 2.0

Description:

ADO.NET 2.0 Captator Tlf: 8620 4242 www.captator.dk Henrik Lykke Nielsen Softwarearkitekt, Microsoft Regional Director for Denmark lykke_at_captator.dk – PowerPoint PPT presentation

Number of Views:92
Avg rating:3.0/5.0
Slides: 36
Provided by: HenrikLyk7
Category:
Tags: ado | net | oledb | presentation

less

Transcript and Presenter's Notes

Title: ADO.NET 2.0


1
ADO.NET 2.0
CaptatorTlf 8620 4242www.captator.dkHenrik
Lykke NielsenSoftwarearkitekt, Microsoft
Regional Director for Denmarklykke_at_captator.dkMo
bil 2237 3311
2
Agenda
  • Providermodellen
  • Basis klasser og interfaces
  • Provider factories, Connectionstrenge
  • Schema API
  • DataSet, DataTable, DataView
  • Indexeringsmekanisme, serialisering
  • SqlBulkCopy
  • Asynkrone kald
  • DataBinding

3
ADO.NET arkitekturen
VS.NET Designers
.NET Data Provider
DataSet
DataAdapter
DataReader
Item
Command
Order
Connection
ltxmlgtlt/xmlgt
4
Basis 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

5
Basis 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
6
Interfaces 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
7
Interfaces 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  
8
Provider 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
9
Provider 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
10
Provider 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
11
ConnectionStrenge
  • 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
12
ConnectionStrenge
  • 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, ...

13
Enumerering 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
14
Fæ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

15
Schema 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
16
Schema - 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
17
Schema - 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
18
Schema - 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
19
DataSet, 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
20
DataSet, DataTable - performance
  • Resultater

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
21
Dataset, 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

22
Dataset, 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
23
DataTable - XML
  • XML understøttelse som for DataSetsReadXml,
    ReadXmlSchemaWriteXml, WriteXmlSchema

24
DataSet, 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
25
DataTable, 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
26
Connection 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
27
Multiple 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
28
UpdateBatchSize 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
29
Asynkrone 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
30
Asynkrone 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
  • 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

31
DataBinding
  • 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

32
DataBinding
  • 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
33
DataBinding
  • 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

34
DataBinding- 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

35
Spørgsmål
www.captator.dknyheder, artikler, information,
...
Write a Comment
User Comments (0)
About PowerShow.com