PetShop学习--SQLServerDAL
来源:互联网 发布:淘宝个人店铺开店流程 编辑:程序博客网 时间:2024/06/14 05:34
中午看了一下SqlServerDAL,画了一个图先贴上来。
SQL数据访问层设计专为SQLServer数据库而设计的。该层是整个项目的最底层!
SQLHelper通过一组静态方法来封装数据的访问功能。
(DAAB.NET SQLHelper完整代码偶全打印出来了,删了一些注释后共21页。留着上课不想听课时候看。)
SQLHelper.cs类为 Account.cs 、Inventory.cs、Item.cs、Order.cs、Product.cs、Profile.cs 六个类的基类。他们都调用SQLHelper.cs类的方法进行功能操作。
如图:
(图好丑哦..)
继续看PetShop的SQLHelper.cs..闪人..
[1]SQLServerDAL的核心-->SQLHelper.cs
今天软考祝露哥 网工考试顺利!~~
Date: 2005-11-5
继续看...
SQLHelper由以下静态方法组成。分别为:
首先看一下PrepareCommand()。因为ExecuteNonQuery() 、ExecuteReader()、ExecuteScalar()都调用了PrepareCommand()!
SqlCommand cmd, //要执行的sql语句或存储过程
SqlConnection conn, //数据库连接字符串
SqlTransaction trans, //数据库事务
CommandType cmdType, //执行数据库的类型 text or StoredProcedure
string cmdText, //SQL语句(存储过程和T-SQL命令)
SqlParameter[] cmdParms //SqlCommand的参数
PrepareCommand主要确定数据库状态是否打开,如果状态为关闭的则打开数据库。数据库事务trans是否不为空,如果不为空则执行事务操作。另外返回一些参数。
再来看看 CacheParameters()在SQLHelper类中首先申明了一个私有静态Hashtable域,该域主要用于存放SQL的参数(cmdParms)。它将在 CacheParameters()用到。
SQLHelper还定义了一个获取缓存参数方法 GetCacheParameters() 用于从Cache中获取缓冲的SQL参数。
ExecuteNonQuery()方法的主要功能是返回受影响的行。它有两个重载,下面列出所有ExecuteNonQuery的重载方法。
ExecuteNonQuery方法
那个using(...)表示数据库操作完成后,自动关闭数据库连接,释放系统资源。
ExecuteNonQuery方法(重载一)
ExecuteReader方法
最后还有一个ExecuteScalar方法。该提供了一个重载。它的主要用途是返回影响数据库记录的行数对象。
PetShop的SqlHelper.cs基本上看完了。在后面的调用中还会返回来学习SQLHelper.cs的。先闪...
SQL数据访问层设计专为SQLServer数据库而设计的。该层是整个项目的最底层!
SQLHelper通过一组静态方法来封装数据的访问功能。
(DAAB.NET SQLHelper完整代码偶全打印出来了,删了一些注释后共21页。留着上课不想听课时候看。)
SQLHelper.cs类为 Account.cs 、Inventory.cs、Item.cs、Order.cs、Product.cs、Profile.cs 六个类的基类。他们都调用SQLHelper.cs类的方法进行功能操作。
如图:
(图好丑哦..)
继续看PetShop的SQLHelper.cs..闪人..
[1]SQLServerDAL的核心-->SQLHelper.cs
今天软考祝露哥 网工考试顺利!~~
Date: 2005-11-5
继续看...
SQLHelper由以下静态方法组成。分别为:
public static int ExecuteNonQuery()
public static SqlDataReader ExecuteReader()
public static object ExecuteScalar()
public static void CacheParameters()
public static SqlParameter[] GetCachedParameters()
private static void PrepareCommand()
public static SqlDataReader ExecuteReader()
public static object ExecuteScalar()
public static void CacheParameters()
public static SqlParameter[] GetCachedParameters()
private static void PrepareCommand()
首先看一下PrepareCommand()。因为ExecuteNonQuery() 、ExecuteReader()、ExecuteScalar()都调用了PrepareCommand()!
private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, CommandType cmdType, string cmdText, SqlParameter[] cmdParms)
{
//连接状态是否打开
if (conn.State != ConnectionState.Open)
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
//Transact-SQL 事务
if (trans != null)
cmd.Transaction = trans;
cmd.CommandType = cmdType;
if (cmdParms != null) {
foreach (SqlParameter parm in cmdParms)
cmd.Parameters.Add(parm);
}
}
PrepareCommand()有6个参数{
//连接状态是否打开
if (conn.State != ConnectionState.Open)
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
//Transact-SQL 事务
if (trans != null)
cmd.Transaction = trans;
cmd.CommandType = cmdType;
if (cmdParms != null) {
foreach (SqlParameter parm in cmdParms)
cmd.Parameters.Add(parm);
}
}
SqlCommand cmd, //要执行的sql语句或存储过程
SqlConnection conn, //数据库连接字符串
SqlTransaction trans, //数据库事务
CommandType cmdType, //执行数据库的类型 text or StoredProcedure
string cmdText, //SQL语句(存储过程和T-SQL命令)
SqlParameter[] cmdParms //SqlCommand的参数
PrepareCommand主要确定数据库状态是否打开,如果状态为关闭的则打开数据库。数据库事务trans是否不为空,如果不为空则执行事务操作。另外返回一些参数。
再来看看 CacheParameters()在SQLHelper类中首先申明了一个私有静态Hashtable域,该域主要用于存放SQL的参数(cmdParms)。它将在 CacheParameters()用到。
public static void CacheParameters(string cacheKey,//缓冲的标识关键字
params SqlParameter[] cmdParms) //SQL参数数组
{
parmCache[cacheKey] = cmdParms;
}
params SqlParameter[] cmdParms) //SQL参数数组
{
parmCache[cacheKey] = cmdParms;
}
SQLHelper还定义了一个获取缓存参数方法 GetCacheParameters() 用于从Cache中获取缓冲的SQL参数。
public static SqlParameter[] GetCachedParameters(string cacheKey) {
SqlParameter[] cachedParms = (SqlParameter[])parmCache[cacheKey];
//如果缓存中为nll则返回空值
if (cachedParms == null)
return null;
SqlParameter[] clonedParms = new SqlParameter[cachedParms.Length];
//复制Cache中的参数
for (int i = 0, j = cachedParms.Length; i < j; i++)
clonedParms[i] = (SqlParameter)((ICloneable)cachedParms[i]).Clone();
return clonedParms;
}
简单的看了一下预先处理的方法再来看三个数据读取的方法咯~SqlParameter[] cachedParms = (SqlParameter[])parmCache[cacheKey];
//如果缓存中为nll则返回空值
if (cachedParms == null)
return null;
SqlParameter[] clonedParms = new SqlParameter[cachedParms.Length];
//复制Cache中的参数
for (int i = 0, j = cachedParms.Length; i < j; i++)
clonedParms[i] = (SqlParameter)((ICloneable)cachedParms[i]).Clone();
return clonedParms;
}
ExecuteNonQuery()方法的主要功能是返回受影响的行。它有两个重载,下面列出所有ExecuteNonQuery的重载方法。
ExecuteNonQuery方法
public static int ExecuteNonQuery(string connString, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
{
SqlCommand cmd = new SqlCommand();
using (SqlConnection conn = new SqlConnection(connString)) {
PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
int val = cmd.ExecuteNonQuery();
cmd.Parameters.Clear();
return val;
}
}
参数依次为:数据库连接字符串,执行命令类型,SQL语句和SQL参数数组。{
SqlCommand cmd = new SqlCommand();
using (SqlConnection conn = new SqlConnection(connString)) {
PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
int val = cmd.ExecuteNonQuery();
cmd.Parameters.Clear();
return val;
}
}
那个using(...)表示数据库操作完成后,自动关闭数据库连接,释放系统资源。
ExecuteNonQuery方法(重载一)
public static int ExecuteNonQuery(SqlConnection conn, CommandType cmdType, string cmdText, params SqlParameter[] cmdparms)
ExecuteNonQuery方法(重载二)public static int ExecuteNonQuery(SqlTransaction trans, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
ExecuteReader方法
public static SqlDataReader ExecuteReader(string connString, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
{
SqlCommand cmd = new SqlCommand();
SqlConnection conn = new SqlConnection(connString);
// we use a try/catch here because if the method throws an exception we want to
// close the connection throw code, because no datareader will exist, hence the
// commandBehaviour.CloseConnection will not work
try {
PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
cmd.Parameters.Clear();
return rdr;
}catch {
conn.Close();
throw;
}
}
ExecuteReader包含四个参数:数据库连接字符串、数据库执行类型、SQL语句和SQL参数数组。主要作用是提供一种从数据库读取只进的行流的一种方式。{
SqlCommand cmd = new SqlCommand();
SqlConnection conn = new SqlConnection(connString);
// we use a try/catch here because if the method throws an exception we want to
// close the connection throw code, because no datareader will exist, hence the
// commandBehaviour.CloseConnection will not work
try {
PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
cmd.Parameters.Clear();
return rdr;
}catch {
conn.Close();
throw;
}
}
最后还有一个ExecuteScalar方法。该提供了一个重载。它的主要用途是返回影响数据库记录的行数对象。
public static object ExecuteScalar(string connstring, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
ExecuteScalar重载public static object ExecuteScalar(SqlConnection conn, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
PetShop的SqlHelper.cs基本上看完了。在后面的调用中还会返回来学习SQLHelper.cs的。先闪...
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=818534
- PetShop学习--SQLServerDAL
- PetShop学习--SQLServerDAL
- 深入宠物店PetShop-SQLServerDAL数据访问与Sample-Duwamish比较
- 深入宠物店PetShop-SQLServerDAL数据访问与Sample-Duwamish比较
- PETSHOP学习
- 初步学习petshop
- petshop经典学习笔记
- PetShop体系结构学习
- PetShop体系结构学习
- petshop学习与提高
- PetShop体系结构学习
- petshop学习笔记(1)
- petshop学习笔记(2)
- PetShop 4.0 体系结构学习
- 学习petshop笔记
- 初步学习petshop
- Petshop 4 学习
- VB.NET学习petshop
- 使用 WS-Notification
- vivi移植
- xxxxx
- MYSQL:Host 'XXXXXX' is blocked because of many connection errors
- Windows Linux Unix 系统的兼容性能与操作系统之间的相对比较
- PetShop学习--SQLServerDAL
- 追MM与设计模式
- linux中用命令修改系统时间
- 快捷键手册
- 面向对象设计的69条经验原则
- [原创]实现类嵌套的方法
- 范式
- ListIterator接口分析
- 棒球联赛中的凶案 - 西村京太郎作品集(6)