DataRabbit 轻量的数据访问框架(07) -- ISPAccesser
(完全限定类名:DataRabbit.Relation.ISPAccesser)
虽然IRelationAccesser可以调用一些不含out参数的存储过程,但是在DataRabbit中调用存储过程最好是通过ISPAccesser接口来进行。
存储过程不仅可以有返回值,还可以有[in,out]参数,在对存储过程的调用进行封装之前,首先必须抽象存储过程的参数表示。DataRabbit使用SPParameter来表示存储过程的参数。

注意,Name属性表示参数名,该参数名不需要带前缀(如"@"),DataRabbit在调用存储过程时会依据数据库的类型自动为其添加合适的参数前缀。
我们可以从DataRabbit的入口点IDataAccesser中获取ISPAccesser引用:
ISPAccesser接口中提供了两个方法以实现对存储过程的调用,其定义如下:
假设,我们现在要调用 复制SqlServer数据库 一文中描述的存储过程,可以这样做:
转到:DataRabbit 轻量的数据访问框架 -- 序
虽然IRelationAccesser可以调用一些不含out参数的存储过程,但是在DataRabbit中调用存储过程最好是通过ISPAccesser接口来进行。
存储过程不仅可以有返回值,还可以有[in,out]参数,在对存储过程的调用进行封装之前,首先必须抽象存储过程的参数表示。DataRabbit使用SPParameter来表示存储过程的参数。
注意,Name属性表示参数名,该参数名不需要带前缀(如"@"),DataRabbit在调用存储过程时会依据数据库的类型自动为其添加合适的参数前缀。
我们可以从DataRabbit的入口点IDataAccesser中获取ISPAccesser引用:
ISPAccesser spAccesser = dataAccesser.GetSPAccesser(null);
ISPAccesser接口中提供了两个方法以实现对存储过程的调用,其定义如下:
public interface ISPAccesser : ITransactionAccesser
{
/// <summary>
/// ExcuteNoneQuery 执行命令式的存储过程,可以输出out参数。
/// </summary>
/// <param name="spName">存储过程名称</param>
/// <param name="parms">所有的[in]和[in,out]参数</param>
/// <param name="outVals">out参数的"名称-值"字典</param>
void ExcuteNoneQuery(string spName, IList<SPParameter> parms, out IDictionary<string, object> outVals);
/// <summary>
/// ExcuteNoneQuery 执行查询式的存储过程,可以输出out参数。
/// </summary>
/// <param name="spName">存储过程名称</param>
/// <param name="parms">所有的[in]和[in,out]参数</param>
/// <param name="outVals">out参数的"名称-值"字典</param>
DataSet ExcuteQuery(string spName, IList<SPParameter> parms, out IDictionary<string, object> outVals);
}
代码的注释已经很好的解释了一切,就不再赘言了。{
/// <summary>
/// ExcuteNoneQuery 执行命令式的存储过程,可以输出out参数。
/// </summary>
/// <param name="spName">存储过程名称</param>
/// <param name="parms">所有的[in]和[in,out]参数</param>
/// <param name="outVals">out参数的"名称-值"字典</param>
void ExcuteNoneQuery(string spName, IList<SPParameter> parms, out IDictionary<string, object> outVals);
/// <summary>
/// ExcuteNoneQuery 执行查询式的存储过程,可以输出out参数。
/// </summary>
/// <param name="spName">存储过程名称</param>
/// <param name="parms">所有的[in]和[in,out]参数</param>
/// <param name="outVals">out参数的"名称-值"字典</param>
DataSet ExcuteQuery(string spName, IList<SPParameter> parms, out IDictionary<string, object> outVals);
}
假设,我们现在要调用 复制SqlServer数据库 一文中描述的存储过程,可以这样做:
IList<SPParameter> paraList = new List<SPParameter>();
SPParameter para1 = new SPParameter("newDbName", ParameterDirection.Input, "EASNew9");
paraList.Add(para1);
SPParameter para2 = new SPParameter("dbDataDirPath", ParameterDirection.Input, @"C:\Program Files\Microsoft SQL Server\MSSQL\Data\");
paraList.Add(para2);
SPParameter para3 = new SPParameter("soureDbName", ParameterDirection.Input, "AutoSchedulerSystem");
paraList.Add(para3);
SPParameter para4 = new SPParameter("soureBackupFilePATH", ParameterDirection.Input, @"d:\sqlDatabase\AutoSchedulerSystem2");
paraList.Add(para4);
IDictionary<string, object> outParas = null;
spAccesser.ExcuteNoneQuery("CopyDB", paraList, out outParas);
SPParameter para1 = new SPParameter("newDbName", ParameterDirection.Input, "EASNew9");
paraList.Add(para1);
SPParameter para2 = new SPParameter("dbDataDirPath", ParameterDirection.Input, @"C:\Program Files\Microsoft SQL Server\MSSQL\Data\");
paraList.Add(para2);
SPParameter para3 = new SPParameter("soureDbName", ParameterDirection.Input, "AutoSchedulerSystem");
paraList.Add(para3);
SPParameter para4 = new SPParameter("soureBackupFilePATH", ParameterDirection.Input, @"d:\sqlDatabase\AutoSchedulerSystem2");
paraList.Add(para4);
IDictionary<string, object> outParas = null;
spAccesser.ExcuteNoneQuery("CopyDB", paraList, out outParas);
转到:DataRabbit 轻量的数据访问框架 -- 序
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构