本文轉載:html
http://www.cnblogs.com/hellokitty1/p/5216025.html#3591383java
本人文筆不行,根據上面博客內容引導,本身整理了一些東西mysql
首先給你們推薦幾個網頁:web
http://blog.csdn.net/isea533/article/category/2092001 沒事看看 - MyBatis工具:www.mybatis.tksql
http://www.mybatis.org/mybatis-3/zh/getting-started.html 入門數據庫
http://www.mybatis.tk/apache
MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,而且更名爲MyBatis 。2013年11月遷移到Github。session
MyBatis 是支持普通 SQL 查詢,存儲過程和高級映射的優秀持久層框架。 MyBatis 消除了幾乎全部的 JDBC 代碼和參數的手工設置以及對結果集的檢索。 MyBatis 可使用簡單的XML 或註解用於配置和原始映射,將接口和 Java 的 POJO( Plain Old Java Objects,普通的Java 對象)映射成數據庫中的記錄.mybatis
1)MyBATIS 目前提供了三種語言實現的版本,包括:Java、.NET以及Ruby。(我主要學習java,就講java的使用)
2)它提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。
3)mybatis與hibernate的對比?
mybatis提供一種「半自動化」的ORM實現。
這裏的「半自動化」,是相對Hibernate等提供了全面的數據庫封裝機制的「全自動化」ORM實現而言,「全自動」ORM實現了POJO和數據庫表之間的映射,以及 SQL 的自動生成和執行。
而mybatis的着力點,則在於POJO與SQL之間的映射關係。
1)首先創建項目java web
2)配置mybatis所需的jar包,pom.xml
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.35</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.2.8</version>
</dependency>
<!-- logback start -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-access</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.3</version>
</dependency>
<!-- logback end -->
3)建立數據庫數據(mybatis),建立表(t_user)
CREATE TABLE `t_user` (
`id` int(11) NOT NULL auto_increment,
`username` varchar(20) default NULL,
`password` varchar(20) default NULL,
`account` double(10,2) default NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8
4)mysql驅動配置文件mysql.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/mybatis
jdbc.username=admin
jdbc.password=123456
5)添加mybatis配置文件mybatis.cfg.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 引入外部配置文件 --> <properties resource="mysql.properties"></properties> <!-- 爲JAVA Bean起類別名 --> <typeAliases > <!-- 別名方式1,一個一個的配置 type中放置的是類的全路徑,alias中放置的是類別名 <typeAliase type="com.cy.mybatis.beans.UserBean" alias="UserBean"/> --> <!-- 別名方式2,自動掃描,將JAVA類的類名做爲類的類別名 --> <package name="com.wenyin.mybatis.beans"/> </typeAliases> <!-- 配置mybatis運行環境 --> <environments default="cybatis"> <environment id="cybatis"> <!-- type="JDBC" 表明使用JDBC的提交和回滾來管理事務 --> <transactionManager type="JDBC" /> <!-- mybatis提供了3種數據源類型,分別是:POOLED,UNPOOLED,JNDI --> <!-- POOLED 表示支持JDBC數據源鏈接池 --> <!-- UNPOOLED 表示不支持數據源鏈接池 --> <!-- JNDI 表示支持外部數據源鏈接池 --> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </dataSource> </environment> </environments> <mappers> <!-- 告知映射文件方式1,一個一個的配置 <mapper resource="com/cy/mybatis/mapper/UserMapper.xml"/>--> <!-- 告知映射文件方式2,自動掃描包內的Mapper接口與配置文件 --> <package name="com/wenyin/mybatis/mapper"/> </mappers> </configuration>
6)建立對應的實體對象
7)建立方法接口UserMapper.java和定義操做t_user表的sql映射文件UserMapper.xml
提供簡單的增刪改查數據信息。
package com.wenyin.mybatis.mapper; import java.util.List; import com.wenyin.mybatis.beans.UserBean; public interface UserMapper { /** * 新增用戶 * @param user * @return * @throws Exception */ public int insertUser(UserBean user) throws Exception; /** * 修改用戶 * @param user * @param id * @return * @throws Exception */ public int updateUser (UserBean user,int id) throws Exception; /** * 刪除用戶 * @param id * @return * @throws Exception */ public int deleteUser(int id) throws Exception; /** * 根據id查詢用戶信息 * @param id * @return * @throws Exception */ public UserBean selectUserById(int id) throws Exception; /** * 查詢全部的用戶信息 * @return * @throws Exception */ public List<UserBean> selectAllUser() throws Exception; }
UserMapper.xml
<?xml version="1.0" encoding="UTF-8"?> <!-- 不寫會報錯 --> <!DOCTYPE mapper PUBLIC "-//mybatis.org/DTD Mapper 3.0" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.wenyin.mybatis.mapper.UserMapper"> <!-- 自定義返回結果集 --> <resultMap id="userMap" type="UserBean"> <id property="id" column="id" javaType="java.lang.Integer"></id> <result property="username" column="username" javaType="java.lang.String"></result> <result property="password" column="password" javaType="java.lang.String"></result> <result property="account" column="account" javaType="java.lang.Double"></result> </resultMap> <!-- 在各類標籤中的id屬性必須和接口中的方法名相同 , id屬性值必須是惟一的,不可以重複使用。parameterType屬性指明查詢時使用的參數類型, resultType屬性指明查詢返回的結果集類型--> <!-- useGeneratedKeys:( 僅 對 insert 有 用 ) 這 會 告 訴 MyBatis 使 用 JDBC 的getGeneratedKeys 方法來取出由數據(好比:像 MySQL 和 SQLServer 這樣的數據庫管理系統的自動遞增字段)內部生成的主鍵。默認值: false。
oracle 不支持應該設置成 useGeneratedKeys="false" 否則會報錯
--> <!--keyProperty: (僅對 insert有用)標記一個屬性, MyBatis 會經過 getGeneratedKeys或者經過 insert 語句的 selectKey 子元素設置它的值。默認:不設置。 --> <!--#{}中的內容,爲佔位符,當參數爲某個JavaBean時,表示放置該Bean對象的屬性值 --> <insert id="insertUser" useGeneratedKeys="true" keyProperty="id"> insert into t_user (username,password,account) values (#{username},#{password},#{account}) </insert> <update id="updateUser" > update t_user set username=#{username},password=#{password},account=#{account} where id=#{id} </update> <delete id="deleteUser" parameterType="int"> delete from t_user where id=#{id} </delete> <select id="selectUserById" parameterType="int" resultMap="userMap"> select * from t_user where id=#{id} </select> <select id="selectAllUser" resultMap="userMap"> select * from t_user </select> </mapper>
這時須要爲mybatis.cfg.xml裏註冊UserMapper.xml文件。
參照第5)步驟
8)須要創建一個工具類文件
package com.wenyin.mybatis.tools; import java.io.Reader; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class DBTools { public static SqlSessionFactory sessionFactory; static{ try { //使用MyBatis提供的Resources類加載mybatis的配置文件 Reader reader = Resources.getResourceAsReader("mybatis.cfg.xml"); //構建sqlSession的工廠 sessionFactory = new SqlSessionFactoryBuilder().build(reader); } catch (Exception e) { e.printStackTrace(); } } //建立能執行映射文件中sql的sqlSession public static SqlSession getSession(){ return sessionFactory.openSession(); } }
9)寫個測試UserService.java
package com.wenyin.mybatis.service; import java.util.List; import org.apache.ibatis.session.SqlSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.wenyin.mybatis.beans.UserBean; import com.wenyin.mybatis.mapper.UserMapper; import com.wenyin.mybatis.tools.DBTools; public class UserService { private static Logger logger = LoggerFactory.getLogger(UserService.class); public static void main(String[] args) { insertUser(); //deleteUser(1); //selectUserById(2); //selectAllUser(); } /** * 新增用戶 */ private static boolean insertUser(){ SqlSession session = DBTools.getSession(); UserMapper mapper = session.getMapper(UserMapper.class); UserBean user = new UserBean("test01", "123456", 7000.0); try { int index=mapper.insertUser(user); boolean bool=index>0?true:false; logger.error("新增用戶user對象:{},操做狀態:{}",new Object[]{user,bool}); session.commit(); return bool; } catch (Exception e) { e.printStackTrace(); session.rollback(); return false; }finally{
session.close();
} } /** * 刪除用戶 * @param id 用戶ID */ private static boolean deleteUser(int id){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { int index=mapper.deleteUser(id); boolean bool=index>0?true:false; logger.debug("根據用戶id:{},操做狀態{}",new Object[]{id,bool}); session.commit(); return bool; } catch (Exception e) { e.printStackTrace(); session.rollback(); return false; }finally{
session.close();
} } /** * 根據id查詢用戶 * @param id */ private static void selectUserById(int id){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { UserBean user= mapper.selectUserById(id); logger.debug("根據用戶Id:{},查詢用戶信息:{}",new Object[]{id,user}); session.commit(); } catch (Exception e) { e.printStackTrace(); session.rollback(); }finally{
session.close();
} } /** * 查詢全部的用戶 */ private static void selectAllUser(){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { List<UserBean> user=mapper.selectAllUser(); logger.debug("獲取所用的用戶:{}",user); session.commit(); } catch (Exception e) { e.printStackTrace(); session.rollback(); }finally{
session.close();
} } }
新增運行結果:
若是返回Map<String,Object>
<select id="getMap" resultType="java.util.HashMap" parameterType="int">
select username,id from
t_user where
id=#{id}
</select>
返回List<Map<String,Object>> <select id="getList" resultType="java.util.HashMap" > SELECT * FROM t_user </select>