1. SmartSqlMap

属性 说明
Scope 域,用于SqlMap定义Sql声明范围

1.1. ResultMap

    <ResultMap Id="UserExtendResultMap">
      <Result Column="Data" Property="Info" TypeHandler="Json"/>
    </ResultMap>
属性 说明
Id 唯一性编号

1.1.1. ResultMap.Result

属性 说明
Column 列名
Property 属性名
TypeHandler 类型处理器,内置(Json/Xml)

1.2. ParameterMap

    <ParameterMap Id="UserExtendParameterMap">
      <Parameter Property="Info" TypeHandler="Json"/>
    </ParameterMap>
属性 说明
Id 唯一性编号

1.2.1. ParameterMap.Parameter

属性 说明
Property 属性名
TypeHandler 类型处理器,内置(Json/Xml)

1.3. MultipleResultMap

    <MultipleResultMap Id="QueryByPage_Map">
      <Result  Property="Total"/>
      <Result  Property="List"/>
    </MultipleResultMap>
    public class QueryByPageResponse
    {
        public int Total { get; set; }
        public IEnumerable<T_Entity> List { get; set; }
    }
属性 说明
Id 唯一性编号

1.3.1. MultipleResultMap.Result

属性 说明
Property 属性

1.4. Statement标签

属性 说明
Id 唯一性编号
Cache 缓存策略编号,引用自Cache标签
CommandType Text/StoredProcedure , Default:Text
SourceChoice Unknow/Write/Read , Default:Unknow
ResultMap ResultMap.Id 用于结果映射,列表VS属性名映射,以及字段类型处理器处理
ParameterMap ParameterMap.Id
MultipleResultMap MultipleResultMap.Id,用于返回多结果集映射

1.5. Statement 筛选子标签

标签 真条件
IsEmpty null or 空字符串 or 空IEnumerable
IsEqual 与比较值相等
IsFalse 参数为 false
IsGreaterEqual 参数大于等于比较值
IsGreaterThan 参数大于比较值
IsLessEqual 参数小于等于比较值
IsLessThan 参数小于比较值
IsNotEmpty !(null or 空字符串 or 空IEnumerable)
IsNotEqual 参数不等于比较值
IsNotNull 参数不等于 null
IsNull 参数等于 null
IsProperty 查询对象包含属性名
IsTrue 参数为 true
Switch Switch 标签
Case Switch标签的子标签,等于比较值
Defalut Switch标签的子标签,未命中任何Case子标签时命中此标签

1.6. Statement 其他子标签

标签 说明
Env 用于判断全局变量 DbProvider
Include 引用外部Statement
Dynamic 动态标签,用于包裹筛选标签,匹配的第一个筛选标签的前缀将忽略
For 用于参数为IEnumerable,遍历参数动态拼接Sql
Where 继承至Dynamic,用于包裹筛选标签,匹配的第一个筛选标签前缀被忽略,并添加 Where 前缀
Set 继承至Dynamic,用于Update,包裹筛选标签,匹配的第一个筛选标签前缀被忽略,并添加 Set 前缀,必须匹配至少一个子标签,否则将抛出SmartSqlException异常。
Placeholder 占位符标签,用于替换参数键值

1.7. Cache 标签

属性 说明
Id 唯一性标号
Type Cache类型继承自ICacheProvider,内置常量:Lru 最近最少使用算法,内存缓存, Fifo 先进先出算法,其他继承自ICacheProvider缓存类型均可,例: Type="SmartSql.Cache.Redis.RedisCacheProvider,SmartSql.Cache.Redis"

1.7.1. Cache 子标签

标签 说明
FlushInterval 定时刷新策略
FlushOnExecute 事件触发策略
Parameter 作为 ICacheProvider 初始化参数

1.7.2. FlushInterval

属性 说明
Hours
Minutes
Seconds

1.7.3. FlushOnExecute

属性 说明
Statement 触发刷新缓存的声明

1.7.4. Parameter

属性 说明
Key
Value