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

上接: [原创] 我的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[下篇]    &

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
What Are the Limitations of Using Views in MySQL?What Are the Limitations of Using Views in MySQL?May 14, 2025 am 12:10 AM

MySQLviewshavelimitations:1)Theydon'tsupportallSQLoperations,restrictingdatamanipulationthroughviewswithjoinsorsubqueries.2)Theycanimpactperformance,especiallywithcomplexqueriesorlargedatasets.3)Viewsdon'tstoredata,potentiallyleadingtooutdatedinforma

Securing Your MySQL Database: Adding Users and Granting PrivilegesSecuring Your MySQL Database: Adding Users and Granting PrivilegesMay 14, 2025 am 12:09 AM

ProperusermanagementinMySQLiscrucialforenhancingsecurityandensuringefficientdatabaseoperation.1)UseCREATEUSERtoaddusers,specifyingconnectionsourcewith@'localhost'or@'%'.2)GrantspecificprivilegeswithGRANT,usingleastprivilegeprincipletominimizerisks.3)

What Factors Influence the Number of Triggers I Can Use in MySQL?What Factors Influence the Number of Triggers I Can Use in MySQL?May 14, 2025 am 12:08 AM

MySQLdoesn'timposeahardlimitontriggers,butpracticalfactorsdeterminetheireffectiveuse:1)Serverconfigurationimpactstriggermanagement;2)Complextriggersincreasesystemload;3)Largertablesslowtriggerperformance;4)Highconcurrencycancausetriggercontention;5)M

MySQL: Is it safe to store BLOB?MySQL: Is it safe to store BLOB?May 14, 2025 am 12:07 AM

Yes,it'ssafetostoreBLOBdatainMySQL,butconsiderthesefactors:1)StorageSpace:BLOBscanconsumesignificantspace,potentiallyincreasingcostsandslowingperformance.2)Performance:LargerrowsizesduetoBLOBsmayslowdownqueries.3)BackupandRecovery:Theseprocessescanbe

MySQL: Adding a user through a PHP web interfaceMySQL: Adding a user through a PHP web interfaceMay 14, 2025 am 12:04 AM

Adding MySQL users through the PHP web interface can use MySQLi extensions. The steps are as follows: 1. Connect to the MySQL database and use the MySQLi extension. 2. Create a user, use the CREATEUSER statement, and use the PASSWORD() function to encrypt the password. 3. Prevent SQL injection and use the mysqli_real_escape_string() function to process user input. 4. Assign permissions to new users and use the GRANT statement.

MySQL: BLOB and other no-sql storage, what are the differences?MySQL: BLOB and other no-sql storage, what are the differences?May 13, 2025 am 12:14 AM

MySQL'sBLOBissuitableforstoringbinarydatawithinarelationaldatabase,whileNoSQLoptionslikeMongoDB,Redis,andCassandraofferflexible,scalablesolutionsforunstructureddata.BLOBissimplerbutcanslowdownperformancewithlargedata;NoSQLprovidesbetterscalabilityand

MySQL Add User: Syntax, Options, and Security Best PracticesMySQL Add User: Syntax, Options, and Security Best PracticesMay 13, 2025 am 12:12 AM

ToaddauserinMySQL,use:CREATEUSER'username'@'host'IDENTIFIEDBY'password';Here'showtodoitsecurely:1)Choosethehostcarefullytocontrolaccess.2)SetresourcelimitswithoptionslikeMAX_QUERIES_PER_HOUR.3)Usestrong,uniquepasswords.4)EnforceSSL/TLSconnectionswith

MySQL: How to avoid String Data Types common mistakes?MySQL: How to avoid String Data Types common mistakes?May 13, 2025 am 12:09 AM

ToavoidcommonmistakeswithstringdatatypesinMySQL,understandstringtypenuances,choosetherighttype,andmanageencodingandcollationsettingseffectively.1)UseCHARforfixed-lengthstrings,VARCHARforvariable-length,andTEXT/BLOBforlargerdata.2)Setcorrectcharacters

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools