在ibatIS中经常会用到: $ 和 # 符号。
一、区别
$aaa$ 输出参数是以字符串方式直接输出 123
#aaa# 输出参数是以Parameter方式输出 @aaa
二、实际应用
1.sqlMap配置文件
<!-- 查询左树菜单 -->
<select id="queryMenu" parameterClass="com.hanpeng.base.phone.model.TEmployeePriv"
resultClass="com.hanpeng.base.phone.model.TEmployeePriv">
SELECT
t1.PRIV_NUM as privNum ,
t1.PRIV_NAME as privName ,
t1.PRIV_PAGE as privPage ,
t1.PRIV_PAGE_DEFAULT as privPageDefault ,
t1.PRIV_URL as privUrl ,
t1.PRIV_INFO as privInfo ,
t1.MENU_ID_1 as menuId1 ,
t1.MENU_ID_2 as menuId2 ,
t1.MENU_ID_3 as menuId3 ,
t1.MENU_ID_DEFAULT as menuIdDefault ,
t1.MENU_RANK_1 as menuRank1 ,
t1.MENU_RANK_2 as menuRank2 ,
t1.MENU_RANK_3 as menuRank3 ,
t1.MENU_RANK_DEFAULT as menuRankDefault ,
t1.RANK as rank ,
t1.RANK_DEFAULT as rankDefault ,
t1.REMARK as remark ,
t1.PRIV_TYPE as privType
FROM T_EMPLOYEE_PRIV t1
left join T_ROLE_PRIV t2 on t1.priv_num=t2.priv_num
left join T_EMPLOYEE_SAFE t3 on t3.role_num=t2.role_num
where t3.employee_id=#employeeId#
order by $menuRank1$
</select>
2.java代码中应用
public List<List<TEmployeePriv>> queryMenu(TEmployeePriv priv)
throws SQLException {
List<TEmployeePriv> allPrivList = new ArrayList<TEmployeePriv>();
List<TEmployeePriv> firstList = new ArrayList<TEmployeePriv>();
List<TEmployeePriv> secondList = new ArrayList<TEmployeePriv>();
String orderType = Converter.getCfgValue("manage_menu_type");//配置表,菜单排序类型
/*if("215".equals(orderType)){
priv.setMenuRank1("t1.menu_rank_1");
}
else if("216".equals(orderType)){
priv.setMenuRank1("t1.menu_rank_2");
}
else if("217".equals(orderType)){
priv.setMenuRank1("t1.menu_rank_3");
}
else{
priv.setMenuRank1("t1.menu_rank_1");
}*/
priv.setMenuRank1("t1.menu_rank_1");//直接设置字符串(死的参数)
priv.setEmployeeId(this.getUserId());//设置参数方式(活的参数)
allPrivList = empDAO.queryMenu(priv);//根据权限查询当前商户的菜单
/*1.加载一级菜单*/
if( allPrivList.size()>0 ){
for( TEmployeePriv firstPriv : allPrivList ){
if(null==firstPriv.getMenuId1()){
firstList.add(firstPriv);//一级菜单
}
}
}
/*2.加载二级菜单*/
for( TEmployeePriv firstPriv : firstList ){
for(TEmployeePriv secondPriv : allPrivList){
if(null!=secondPriv.getMenuId1()&&
firstPriv.getPrivNum().equals(secondPriv.getMenuId1())){
secondList.add(secondPriv);
}
}
}
List<List<TEmployeePriv>> result = new ArrayList<List<TEmployeePriv>>();
result.add(firstList);
result.add(secondList);
return result;
}
分享到:
相关推荐
### ibatis中 $ 与 # 的区别 在ibatis(现称为MyBatis)框架中,$ 和 # 是两种不同的动态SQL元素标记,用于处理参数传递的问题。它们各自有着独特的功能和应用场景,对于理解这两者的差异是十分重要的,因为这会...
在使用iBATIS(现已被MyBatis取代)进行数据库操作时,我们常常需要传递参数到SQL语句中。在iBATIS中,有两种主要的方式来处理这些参数:使用`$`和`#`。这两种方式在不同的场景下有不同的效果。 首先,让我们来看看...
### ibatis中输入输出各种类型的参数分析及#与$区别 #### iBatis简介与特点 iBatis作为一款轻量级的Java持久层框架,以其简洁、灵活的特点,在众多框架中占据一席之地。相较于知名的Hibernate框架,iBatis在实现上...
### myBatis与ibatis的区别 #### 一、概述 myBatis与ibatis是两款在Java领域中非常流行的持久层框架,它们均基于SQL映射机制,为开发者提供了便捷的方式来处理数据库操作。两者间的关系密切,ibatis是myBatis的...
- **缓存机制**:介绍iBATIS中的缓存机制,包括一级缓存和二级缓存的区别及使用方法。 - **调优技巧**:提供一系列性能优化建议,如合理使用缓存、优化SQL语句等。 #### 3.2 数据访问对象 - **DAO模式**:阐述DAO...
虽然 iBatis 在某些方面与 Hibernate 类似,但它们之间的主要区别在于 iBatis 提供了更细粒度的 SQL 控制能力,这使得 iBatis 在复杂查询或性能敏感的应用场景中更具优势。 ### 二、动态 SQL 的概念 在实际应用中...
### iBatis与Hibernate的主要区别 #### 一、概述 iBatis与Hibernate都是Java领域内流行的ORM(Object-Relational Mapping,对象关系映射)框架,用于简化Java应用程序与数据库之间的交互。尽管它们有着相似的目标,...
- iBatis .NET简介:介绍iBatis .NET的基本概念、设计理念以及与传统数据访问方式的区别。 - 安装与配置:指导如何在.NET项目中引入iBatis .NET,以及如何设置配置文件。 - 数据库映射:讲解如何创建XML映射文件或...
#### 二、iBatis与Hibernate的区别 ##### 2.1 ORM实现方式 - **iBatis**:半自动化的ORM实现。iBatis关注于SQL与Java对象之间的映射,而不是像Hibernate那样自动生成SQL。 - **Hibernate**:全自动化ORM实现。...
五、iBatis与MyBatis的区别与联系 MyBatis是iBatis的升级版,它继承了iBatis的所有优点,并做了很多改进,比如引入了注解支持、增强了对Spring的整合等。MyBatis更加现代化,社区活跃,持续维护,而iBatis则停止了...
ibatis与Hibernate、Apache OJB等其他ORM框架的主要区别在于其半自动化的特点。对于需要精细控制SQL语句的应用场景,ibatis提供了更灵活的选择。例如,在以下情况下,ibatis可能是更好的选择: - 当数据库表结构...
### ibatis与hibernate的区别 #### 一、概述 在Java开发领域中,持久化技术是连接应用程序与数据库之间的重要桥梁。其中,ibatis(现称为MyBatis)和Hibernate作为两种主流的对象关系映射(Object Relational ...
**选用Ibatis与Hibernate的区别**: 1. **灵活性**:Ibatis允许直接编写SQL,适合复杂的查询和性能优化。Hibernate则倾向于自动化,可能在复杂查询方面不够灵活。 2. **学习曲线**:Hibernate提供了全套的ORM解决...
#### 二、ibatis与全自动化ORM工具的区别 ibatis之所以被称为“半自动化”的ORM实现,主要是因为它并不像Hibernate或Apache OJB那样提供对数据库结构的完全封装。使用ibatis时,开发者需要自己编写SQL语句,并通过...
在Java开发中,ibatis和Hibernate都是常见的对象关系映射(ORM)框架,它们简化了数据库操作,将Java对象与数据库表之间的映射关系抽象出来,使得开发人员可以使用面向对象的方式处理数据。然而,两者在设计理念和...
##### 2.3 iBATIS高速缓存和传统O/RM高速缓存的区别 iBATIS高速缓存相较于传统的对象关系映射(ORM)工具的缓存机制,更侧重于简单性和灵活性。例如,iBATIS允许开发者自由地控制缓存的配置,而传统ORM工具可能会有...
ibatis被称为“半自动化”ORM,意味着它在对象与关系型数据库之间的映射过程中保留了一定的手动控制空间。与Hibernate和Apache OJB相比,这些工具通常提供了完整的数据库表结构封装,允许开发者仅通过定义映射关系就...
iBATIS是一个优秀的Java持久层框架,它提供了一个SQL映射框架,使开发者能够将SQL语句直接写在配置文件中,与Java代码分离,从而实现了数据访问逻辑和业务逻辑的解耦。"ibatis2.rar"这个压缩包文件包含了关于iBATIS ...
### MySQL、JDBC详解及与iBatis对比 #### 一、MySQL基本操作 MySQL作为一款广泛使用的开源关系型数据库管理系统,在IT行业中占有极其重要的地位。对于开发人员来说,掌握MySQL的基本操作至关重要。 ##### 1. 增删...
4. **参数映射与结果集映射**:Ibatis提供了强大的参数映射机制,如#{}和${}的区别,以及如何使用Map、POJO、自定义VO等方式传递参数。同时,它还支持自动映射结果集,也可以自定义映射规则。 5. **缓存机制**:...