iBATIS In Action:使用映射语句(二)

iBATIS In Action:使用映射语句(二)

ID:37276500

大小:58.50 KB

页数:8页

时间:2019-05-20

iBATIS In Action:使用映射语句(二)_第1页
iBATIS In Action:使用映射语句(二)_第2页
iBATIS In Action:使用映射语句(二)_第3页
iBATIS In Action:使用映射语句(二)_第4页
iBATIS In Action:使用映射语句(二)_第5页
资源描述:

《iBATIS In Action:使用映射语句(二)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、4.3映射参数(MappingParameters)对于大多数SQL语句来说,它们有用是因为我们可以在运行时向其传入参数。有两种方式可以将参数(parameter)映射到语句中:内联(inline)参数和外部(external)参数。使用内联参数,配置一般较为简单,iBATIS会根据您的配置进行“揣测”,以获取其它细节信息。而使用外部参数时,配置一般更为显式的(具体)——因为您告诉iBATIS它该如何去做。4.3.1外部参数映射参数映射(ParameterMap)定义了一个参数的有序列表,它与查询语句的占位符相匹配。注意,参数对象的属性定义可以按任意顺序,参数映射会确保每个值得以正确地传

2、入。使用外部参数映射时,我们可以指定多达10个的特性。如果没有完全指定,iBATIS会藉由反射来确定出一些合理的默认值,这个过程会花费一定的时间,也有可能不够准确。表4.4列出了适用于映射参数的特性,并对其做了简要的介绍。映射参数的特性(attribute)特性描述property表示参数对应的对象的属性名称。如果输入参数对象为IDictionary,则property是相应key的名称。同一property值可以出现多次,这取决于它在语句中出现的次数。column用于定义存储过程的参数名称。direction可用于指定存储过程参数的方向。其值可以是Input,Output或InputO

3、utput。dbType用于显式地指定参数对应的列类型。对于某些操作,一些ADO.NETprovider不能判断列的类型,此时dbType必须指定。此特性仅在列为nullable时是必需的。此外,在显式指定日期类型时也需要此特性。尽管.NET仅有一种日期值类型(System.DateTime),大多数数据库却不止一个。通常情况下,数据库至少有三种不同的日期类型(Date,DateTime,TimeStamp)。为使映射过程能够正确,我们可能需要指定列的dbType。type用于指定前面的property的CLR类型。在向存储过程传入InputOput和Output类型的参数时,该特性很有

4、用。正常情况下,property的类型可通过反射获得,但对于IDictionary类型的参数就无能为力了,此时类型被假定为Object。nullValuenullValue可以设置为任何的有效值(这取决于property的类型)。注意:对于值类型(int,double,datetime等)的属性,它们是不能为null的,那如何向数据库中插入null值呢?可以采用nullValue,比如对于Age列(int类型),我们可以指定nullValue为0,这意味着如果该属性未设置(C#中,int属性的默认值为0),那么会向数据库插入NULL。在.NET2.0中也可以使用nullable类型,此时

5、更为方便。请参考我的小文。size设置列的最大尺寸。precision设置数字值的精度。scale设置小数的位数。typeHandler用于自定义类型处理器(CustomTypeHandler)。内联参数在多数情况下效果不错。如果您希望改善性能,或者遇到了意外的情况,外部参数可能就用得上了。在第5章中,我们会更全面地讨论外部参数,在这里,暂不需要。4.3.2重温内联参数如果您更喜欢使用内联参数,同样可以为参数指定更多的信息,如属性的类型,类的类型以及null值替换(即nullValue特性)。看下面四个例子:

6、ss="Product">insertintoPRODUCT(PRD_ID,PRD_DESCRIPTION)values(#id#,#description#)这是最简单的情况,下面这个例子指定了dbType:insertintoPRODUCT(PRD_ID,PRD_DESCRIPTION)values(#id:int#,#description:VarChar#)下面这个例子指定了nullValue:

7、ertProduct"parameterClass="Product">insertintoPRODUCT(PRD_ID,PRD_DESCRIPTION)values(#id:int:-999999#,#description:VarChar#)类似于Java中的DataMapper,内联参数还有另外一种语法,使用逗号。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。