[TOC]
# if標簽
sql
~~~
<!-- 根據性別和名字查詢用戶 -->
<select id="selectUserBySexAndUsername" parameterType="pojo.User" resultType="pojo.User">
select * from user
where
<if test="sex != null and sex != ''">
sex = #{sex}
</if>
<if test="username != null and username != ''">
and username = #{username}
</if>
</select>
~~~
接口
~~~
// 根據性別和名稱查詢用戶
public List<User> selectUserBySexAndUsername(User user);
~~~
測試
~~~
// 加載核心配置文件
String resource = "SqlMapConfig.xml";
InputStream in = Resources.getResourceAsStream(resource);
// 創建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
// 創建SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
// SqlSession幫我生成一個實現類
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = new User();
user.setSex("1");
user.setUsername("張小明");
List<User> users = mapper.selectUserBySexAndUsername(user);
for (User user2 : users) {
System.out.println(user2);
}
~~~
# where
我們把sql改造下
~~~
<!-- 根據性別和名字查詢用戶 -->
<select id="selectUserBySexAndUsername" parameterType="pojo.User" resultType="pojo.User">
select * from user
<where>
<if test="sex != null and sex != ''">
sex = #{sex}
</if>
<if test="username != null and username != ''">
and username = #{username}
</if>
</where>
</select>
~~~
# sql片段
~~~
<sql id="selector">
select * from user
</sql>
<!-- 根據性別和名字查詢用戶 -->
<select id="selectUserBySexAndUsername" parameterType="pojo.User" resultType="pojo.User">
<include refid="selector"></include>
<where>
<if test="sex != null and sex != ''">
sex = #{sex}
</if>
<if test="username != null and username != ''">
and username = #{username}
</if>
</where>
</select>
~~~
# foreach標簽
向sql傳遞數組或list,mybatis使用foreach解析
根據多個id查詢用戶信息,查詢sql,select * from user where id in (1,10,24)
接口
~~~
public List<Orders> selectUserByIds(QueryVo vo);
~~~
QueryVo這個pojo類中添加
~~~
List<Integer> idsList;
public List<Integer> getIdsList() {
return idsList;
}
public void setIdsList(List<Integer> idsList) {
this.idsList = idsList;
}
~~~
sql
~~~
<sql id="selector">
select * from orders
</sql>
<!-- 多個id (1,2,3) -->
<select id="selectUserByIds" parameterType="pojo.QueryVo" resultType="pojo.Orders">
<include refid="selector" />
<where>
id in
<foreach collection="idsList" item="id" separator="," open="(" close=")">
#{id}
</foreach>
</where>
</select>
~~~
測試
~~~
// 加載核心配置文件
String resource = "SqlMapConfig.xml";
InputStream in = Resources.getResourceAsStream(resource);
// 創建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
// 創建SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
// SqlSession幫我生成一個實現類
// UserMapper mapper = sqlSession.getMapper(UserMapper.class);
OrderMapper mapper = sqlSession.getMapper(OrderMapper.class);
List<Integer> ids = new ArrayList<>();
ids.add(3);
ids.add(4);
QueryVo vo = new QueryVo();
vo.setIdsList(ids);
List<Orders> rel = mapper.selectUserByIds(vo);
for (Orders order : rel) {
System.out.println(order);
}
~~~
**另一種**
寫接口
~~~
public List<Orders> selectOrdersByIds(Integer[] ids);
~~~
配置文件
~~~
<!-- 多個id (1,2,3) -->
<select id="selectOrdersByIds" parameterType="pojo.QueryVo" resultType="pojo.Orders">
<include refid="selector" />
<where>
id in
<foreach collection="array" item="id" separator="," open="(" close=")">
#{id}
</foreach>
</where>
</select>
~~~
這邊要寫array的
測試
~~~
// 加載核心配置文件
String resource = "SqlMapConfig.xml";
InputStream in = Resources.getResourceAsStream(resource);
// 創建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
// 創建SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
// SqlSession幫我生成一個實現類
OrderMapper mapper = sqlSession.getMapper(OrderMapper.class);
Integer[] ids = new Integer[3];
ids[0] = 3;
ids[1] = 4;
ids[2] = 5;
List<Orders> rel = mapper.selectOrdersByIds(ids);
for (Orders order : rel) {
System.out.println(order);
}
~~~
- 基礎
- 編譯和安裝
- scanner類(鍵盤錄入)
- Random類(隨機數)
- 數組
- 方法
- 類
- ArrayList集合
- char與int
- eclipse
- IDEA
- 變量與常量
- 常用API
- String,StringBuffer,StringBuilder
- 正則,Date,DateFormat,Calendar
- 包裝類,System,Math,Arrays,BigInteger,BigDecimal
- 集合,迭代器,增強for,泛型
- List,set,判斷集合唯一
- map,Entry,HashMap,Collections
- 異常
- IO
- File
- 遞歸
- 字節流
- 字符流
- IO流分類
- 轉換流
- 緩沖流
- 流的操作規律
- properties
- 序列化流與反序列化流
- 打印流
- commons-IO
- IO流總結
- 多線程
- 線程池
- 線程安全
- 線程同步
- 死鎖
- lock接口
- ThreadLoad
- 等待喚醒機制
- 線程狀態
- jdbc
- DBUtils
- 連接池DBCP
- c3p0連接池
- 網絡編程
- 多線程socket上傳圖片
- 反射
- xml
- 設計模式
- 裝飾器模式
- web service
- tomcat
- Servlet
- response
- request
- session和cookie
- JSP
- EL
- JSTL
- 事務
- 監聽器Listener
- 過濾器Filter
- json
- linux安裝軟件
- 反射詳解
- 類加載器和注解
- 動態代理
- jedis
- Hibernate
- 簡介
- 創建映射文件
- Hibernate核心配置文件
- 事務和增刪改查
- HibernateUtils
- 持久化對象的三種狀態
- 檢索方式
- query
- Criteria
- SQLQuery
- 持久化類
- 主鍵生成策略
- 緩存
- 事務管理
- 關系映射
- 注解
- 優化
- struts2
- 搭建
- 配置詳解
- Action
- 結果跳轉方式
- 訪問ServletAPI方式
- 如何獲得參數
- OGNL表達式
- valueStack 值棧
- Interceptor攔截器
- spring
- 導包
- IOC和DI
- Bean獲取與實例化
- Bean屬性注入
- spring注解
- 注解分層
- junit整合
- aop
- 動態代理實現
- cglib代理實現
- aop名詞
- spring的aop
- aop-xml詳解
- aop-注解詳解
- 代理方式選擇
- jdbcTemplate
- spring事務管理
- 回滾注意
- 事務傳播屬性
- MyBatis
- MyBatis簡介
- 入門程序
- 與jdbc hibernate不同
- 原始Dao開發
- Mapper動態代理方式
- SqlMapConfig.xml配置文件
- 輸入參數pojo包裝類
- resultMap
- 動態sql
- 一對一關聯
- 一對多
- 整合spring
- 逆向工程
- maven
- maven簡介
- 倉庫
- maven目錄結構
- maven常用命令
- 生命周期
- eclipse中maven插件
- 入門程序
- 整合struct
- 依賴范圍
- 添加插件
- idea配置
- jar包沖突
- 分模塊開發
- 構建可執行的jar包(包含依賴jar包)
- springMVC
- 處理流程
- java面試
- java版本升級
- java1-8版本變更
- java9新特性
- 鎖
- java資料
- idea
- jdk版本切換
- log4j
- 入門實例
- 基本使用方法
- Web中使用Log4j
- spring中使用log4j
- java代碼優化