Rumah pangkalan data tutorial mysql 开发自己的Data Access Application Block[下篇]

开发自己的Data Access Application Block[下篇]

Jun 07, 2016 pm 03:48 PM
access application data membangun sendiri

上接: [原创] 我的ORM: 开发自己的Data Access Application Block - Part I 4. Database 下面来介绍重中之重:Database,绝大部分的DataAccess 操作都集中在这个Abstract Database中。这是一个相对庞大的Class,所以不得不采用Partial Class的方式来编写。

上接:[原创] 我的ORM: 开发自己的Data Access Application Block - Part I
4. Database

下面来介绍重中之重:Database,绝大部分的Data Access 操作都集中在这个Abstract Database中。这是一个相对庞大的Class,所以不得不采用Partial Class的方式来编写。

Part I:Field 和Property

这些Field 和Property基本上对应我们前面的Configuraiton。此为我们定义了三个Field 和Property:DbDataAdapter,Connection,_transaction。考虑到垃圾回收,使Database实现IDisposable接口。值得说明一点的是,我们通过Database的DatabaseProviderFactory创建了泛型的DbDataAdapter,DbConnection和Transaction。

  • ConnectionString:string

  • DatabaseProviderFactory:DbProviderFactory

  • DefaultCommandType:CommandType

  • UseCommandBuilder:bool

  • DbParameterNameMapping:IDbParameterNameMapping

  • StoredProcedureNameMapping:IStoredProcedureNameMapping

  • DbDataAdapter:DbDataAdapter

  • Connection: DbConnection

  • Transaction: DbTransaction

开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]using System;
开发自己的Data Access Application Block[下篇]
using System.Collections.Generic;
开发自己的Data Access Application Block[下篇]
using System.Text;
开发自己的Data Access Application Block[下篇]
using System.Data;
开发自己的Data Access Application Block[下篇]
using System.Data.Common;
开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]
using Artech.ApplicationBlock.DataMapping;
开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]
namespace Artech.ApplicationBlock.DataAccess
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]    
/**//// 


开发自己的Data Access Application Block[下篇]    
/// Database defines a series of database-based operations.
开发自己的Data Access Application Block[下篇]    
/// 
开发自己的Data Access Application Block[下篇]    public abstract partial class Database : IDisposable
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]    
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]        
private bool _isDisposed;
开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
The five private fields possess the corressponding pubic properties, and they are only allowed to be evaluated by Database Factory.#region The five private fields possess the corressponding pubic properties, and they are only allowed to be evaluated by Database Factory.
开发自己的Data Access Application Block[下篇]        
private DbProviderFactory _dbProviderFactory;
开发自己的Data Access Application Block[下篇]        
private string _connectionString;
开发自己的Data Access Application Block[下篇]        
private CommandType _defaultCommandType;
开发自己的Data Access Application Block[下篇]        
private bool _useCommandBuilder;
开发自己的Data Access Application Block[下篇]        
private IDbParameterNameMapping _dbParameterNameMapping;
开发自己的Data Access Application Block[下篇]        
private IStoredProcedureNameMapping _storedProcedureNameMapping;
开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// Database connection string which is specified by the database factory.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public string ConnectionString
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._connectionString;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._connectionString = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// The concrete database specific provider factory.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public DbProviderFactory DatabaseProviderFactory
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._dbProviderFactory;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._dbProviderFactory = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// The defaull command type to perform the database operations which do not specify the commanf type.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public CommandType DefaultCommandType
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._defaultCommandType;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._defaultCommandType = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
///Determine whether to use command builder or mapped stored procedures to execute database operations.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public bool UseCommandBuilder
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._useCommandBuilder;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._useCommandBuilder = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// A string which indicates the type to perform mapping between stored procedure parameter and source column.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public IDbParameterNameMapping DbParameterNameMapping
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._dbParameterNameMapping;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._dbParameterNameMapping = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// A string which indicates the type to perform mapping between table name and the related stored procedure names.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        public IStoredProcedureNameMapping StoredProcedureNameMapping
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
return this._storedProcedureNameMapping;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]            
set
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
this._storedProcedureNameMapping = value;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]        
#endregion

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
Connection & Database DataAdapter#region Connection & Database DataAdapter
开发自己的Data Access Application Block[下篇]        
private DbDataAdapter _dbDataAdapter;
开发自己的Data Access Application Block[下篇]        
private DbConnection _connection;
开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// A generic database data adapter which is responsible for save the changed data into database.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        private DbDataAdapter DatabaseAdapter
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
if (this._dbDataAdapter == null)
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]                
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                    
this._dbDataAdapter = this._dbProviderFactory.CreateDataAdapter();
开发自己的Data Access Application Block[下篇]                    
this._dbDataAdapter.AcceptChangesDuringUpdate = false;
开发自己的Data Access Application Block[下篇]                    
this._dbDataAdapter.MissingSchemaAction = MissingSchemaAction.Add;
开发自己的Data Access Application Block[下篇]                }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]                
return this._dbDataAdapter;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
/**//// 
开发自己的Data Access Application Block[下篇]        
/// The database connection.
开发自己的Data Access Application Block[下篇]        
/// 

开发自己的Data Access Application Block[下篇]        private DbConnection Connection
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]            
get
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]            
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                
if (this._connection == null)
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]                
开发自己的Data Access Application Block[下篇]{
开发自己的Data Access Application Block[下篇]                    
this._connection = this._dbProviderFactory.CreateConnection();
开发自己的Data Access Application Block[下篇]                    
this._connection.ConnectionString = this._connectionString;
开发自己的Data Access Application Block[下篇]                }

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]                
return this._connection;
开发自己的Data Access Application Block[下篇]            }

开发自己的Data Access Application Block[下篇]        }

开发自己的Data Access Application Block[下篇]        
#endregion

开发自己的Data Access Application Block[下篇]
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]        
Constructor#region Constructor
开发自己的Data Access Application Block[下篇]        
public Database()
开发自己的Data Access Application Block[下篇]开发自己的Data Access Application Block[下篇]    &

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk melumpuhkan aplikasi latar belakang dalam Windows 11_Windows 11 tutorial untuk melumpuhkan aplikasi latar belakang Bagaimana untuk melumpuhkan aplikasi latar belakang dalam Windows 11_Windows 11 tutorial untuk melumpuhkan aplikasi latar belakang May 07, 2024 pm 04:20 PM

1. Buka tetapan dalam Windows 11. Anda boleh menggunakan pintasan Win+I atau mana-mana kaedah lain. 2. Pergi ke bahagian Apl dan klik Apl & Ciri. 3. Cari aplikasi yang anda ingin halang daripada berjalan di latar belakang. Klik butang tiga titik dan pilih Pilihan Lanjutan. 4. Cari bahagian [Background Application Permissions] dan pilih nilai yang dikehendaki. Secara lalai, Windows 11 menetapkan mod pengoptimuman kuasa. Ia membolehkan Windows mengurus cara aplikasi berfungsi di latar belakang. Sebagai contoh, sebaik sahaja anda mendayakan mod penjimat bateri untuk mengekalkan bateri, sistem akan menutup semua apl secara automatik. 5. Pilih [Jangan sekali-kali] untuk menghalang aplikasi daripada berjalan di latar belakang. Sila ambil perhatian bahawa jika anda perasan bahawa program tidak menghantar pemberitahuan kepada anda, gagal mengemas kini data, dsb., anda boleh

Empat alat pengaturcaraan berbantukan AI yang disyorkan Empat alat pengaturcaraan berbantukan AI yang disyorkan Apr 22, 2024 pm 05:34 PM

Alat pengaturcaraan berbantukan AI ini telah menemui sejumlah besar alat pengaturcaraan berbantukan AI yang berguna dalam peringkat pembangunan AI yang pesat ini. Alat pengaturcaraan berbantukan AI boleh meningkatkan kecekapan pembangunan, meningkatkan kualiti kod dan mengurangkan kadar pepijat Ia adalah pembantu penting dalam proses pembangunan perisian moden. Hari ini Dayao akan berkongsi dengan anda 4 alat pengaturcaraan berbantukan AI (dan semua menyokong bahasa C# saya harap ia akan membantu semua orang). https://github.com/YSGStudyHards/DotNetGuide1.GitHubCopilotGitHubCopilot ialah pembantu pengekodan AI yang membantu anda menulis kod dengan lebih pantas dan dengan sedikit usaha, supaya anda boleh lebih memfokuskan pada penyelesaian masalah dan kerjasama. Git

Cara menukar pdf deepseek Cara menukar pdf deepseek Feb 19, 2025 pm 05:24 PM

DeepSeek tidak dapat menukar fail terus ke PDF. Bergantung pada jenis fail, anda boleh menggunakan kaedah yang berbeza: dokumen biasa (Word, Excel, PowerPoint): Gunakan Microsoft Office, LibreOffice dan perisian lain untuk dieksport sebagai PDF. Imej: Simpan sebagai PDF Menggunakan Image Viewer atau Perisian Pemprosesan Imej. Halaman Web: Gunakan fungsi "Print Into PDF" penyemak imbas atau laman web yang berdedikasi ke alat PDF. Format yang tidak biasa: Cari penukar yang betul dan tukarnya ke PDF. Adalah penting untuk memilih alat yang betul dan membangunkan pelan berdasarkan keadaan sebenar.

Tidak boleh membenarkan akses kepada kamera dan mikrofon dalam iPhone Tidak boleh membenarkan akses kepada kamera dan mikrofon dalam iPhone Apr 23, 2024 am 11:13 AM

Adakah anda mendapat "Tidak dapat membenarkan akses kepada kamera dan mikrofon" apabila cuba menggunakan apl itu? Biasanya, anda memberikan kebenaran kamera dan mikrofon kepada orang tertentu berdasarkan keperluan untuk disediakan. Walau bagaimanapun, jika anda menafikan kebenaran, kamera dan mikrofon tidak akan berfungsi dan sebaliknya akan memaparkan mesej ralat ini. Menyelesaikan masalah ini adalah sangat asas dan anda boleh melakukannya dalam satu atau dua minit. Betulkan 1 – Sediakan Kebenaran Kamera, Mikrofon Anda boleh memberikan kebenaran kamera dan mikrofon yang diperlukan secara terus dalam tetapan. Langkah 1 – Pergi ke tab Tetapan. Langkah 2 – Buka panel Privasi & Keselamatan. Langkah 3 – Hidupkan kebenaran "Kamera" di sana. Langkah 4 – Di dalam, anda akan menemui senarai apl yang telah meminta kebenaran untuk kamera telefon anda. Langkah 5 – Buka "Kamera" apl yang ditentukan

Apakah maksud medan dalam java Apakah maksud medan dalam java Apr 25, 2024 pm 10:18 PM

Di Java, "medan" ialah ahli data dalam kelas atau antara muka yang digunakan untuk menyimpan data atau keadaan. Atribut medan termasuk: jenis (boleh menjadi mana-mana jenis data Java), hak akses, statik (kepunyaan kelas dan bukannya contoh), muktamad (tidak berubah) dan sementara (tidak bersiri). Medan digunakan untuk menyimpan maklumat keadaan kelas atau antara muka, seperti menyimpan data objek dan mengekalkan keadaan objek.

Bagaimanakah mekanisme refleksi Java mengubah suai tingkah laku kelas? Bagaimanakah mekanisme refleksi Java mengubah suai tingkah laku kelas? May 03, 2024 pm 06:15 PM

Mekanisme refleksi Java membolehkan program mengubah suai tingkah laku kelas secara dinamik tanpa mengubah suai kod sumber. Dengan mengendalikan kelas melalui objek Kelas, anda boleh membuat contoh melalui newInstance(), mengubah suai nilai medan peribadi, memanggil kaedah peribadi, dsb. Refleksi harus digunakan dengan berhati-hati, walau bagaimanapun, kerana ia boleh menyebabkan tingkah laku dan isu keselamatan yang tidak dijangka serta mempunyai overhed prestasi.

Bagaimana untuk membaca fail dbf dalam oracle Bagaimana untuk membaca fail dbf dalam oracle May 10, 2024 am 01:27 AM

Oracle boleh membaca fail dbf melalui langkah-langkah berikut: buat jadual luaran dan rujuk fail dbf untuk mendapatkan semula data yang diimport ke dalam jadual Oracle;

Apakah rupa kayu memori? Apakah rupa kayu memori? Apr 21, 2024 pm 01:01 PM

Apakah rupa modul memori komputer Ini ialah gambaran keseluruhan kad grafik dan modul memori dalam komputer. Kad grafik bebas komputer dimasukkan ke dalam slot kad grafik, dengan kipas, dan modul memori berada di dalam slot modul memori pada motherboard komputer, berbentuk seperti selari segi empat tepat hijau. Modul memori komputer riba adalah berbeza daripada modul memori desktop, dan ia tidak boleh digunakan secara bergantian. Perbezaan rupa 1: Memori desktop adalah langsing, dengan panjang 13-14 cm. 2: Memori buku nota lebih pendek, kira-kira lima sentimeter. Memori adalah jambatan dalam komputer, bertanggungjawab untuk pertukaran data antara pemproses dan perkakasan seperti cakera keras, papan induk, dan kad grafik. Bulatan merah dalam perjalanan ialah memory stick, bersebelahan dengan kipas CPU dan dipasang pada memory stick. Lihat, kayu memori komputer kelihatan seperti ini. Gunakan pemutar skru untuk membuka penutup komputer meja Lingkaran merah di tengah ialah modul memori. Apakah kayu memori?

See all articles