`
changhongbao
  • 浏览: 123105 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

1.Mybatis介绍和简单使用

 
阅读更多

1.Mybatis介绍


MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.

2.mybatis快速入门


编写第一个基于mybaits的测试例子:
2.1. 添加jar包

【mybatis】
 mybatis-3.1.1.jar
【MYSQL驱动包】
 mysql-connector-java-5.1.7-bin.jar

 

2.2. 建库+表

create database mybatis;
use mybatis;
CREATE TABLE users(id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(20), age INT);
INSERT INTO users(NAME, age) VALUES('Tom', 12);
INSERT INTO users(NAME, age) VALUES('Jack', 11);

 

2.3.添加Mybatis的配置文件conf.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>
	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="com.mysql.jdbc.Driver" />
				<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
				<property name="username" value="root" />
				<property name="password" value="root" />
			</dataSource>
		</environment>
	</environments>
</configuration>

 

2.4. 定义表所对应的实体类

public class User {
	private int id;
	private String name;
	private int age;
    //get,set方法
}

 

2.5.定义操作users表的sql映射文件userMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="com.atguigu.mybatis_test.test1.userMapper"> 
	<select id="getUser" parameterType="int" 
		resultType="com.atguigu.mybatis_test.test1.User">
		select * from users where id=#{id}
	</select>
</mapper>

 

2.6. 在conf.xml文件中注册userMapper.xml文件 

 

<mappers>
	<mapper resource="com/atguigu/mybatis_test/test1/userMapper.xml"/>
</mappers>

 
2.7. 编写测试代码:执行定义的select语句 

 

public class Test {
	public static void main(String[] args) throws IOException {
		String resource = "conf.xml"; 
		//加载mybatis的配置文件(它也加载关联的映射文件)
		Reader reader = Resources.getResourceAsReader(resource); 
		//构建sqlSession的工厂
		SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
		//创建能执行映射文件中sql的sqlSession
		SqlSession session = sessionFactory.openSession();
		//映射sql的标识字符串
		String statement = "com.atguigu.mybatis.bean.userMapper"+".selectUser";
		//执行查询返回一个唯一user对象的sql
		User user = session.selectOne(statement, 1);
		System.out.println(user);
	}
}

 

3. 操作users表的CRUD

3.1. XML的实现
1). 定义sql映射xml文件:

<insert id="insertUser" parameterType="com.atguigu.ibatis.bean.User">
	insert into users(name, age) values(#{name}, #{age});
</insert>

<delete id="deleteUser" parameterType="int">
	delete from users where id=#{id}
</delete>
		
<update id="updateUser" parameterType="com.atguigu.ibatis.bean.User">
	update users set name=#{name},age=#{age} where id=#{id}
</update>
		
<select id="selectUser" parameterType="int" resultType="com.atguigu.ibatis.bean.User">
	select * from users where id=#{id}
</select>
		
<select id="selectAllUsers" resultType="com.atguigu.ibatis.bean.User">
	select * from users
</select>

2). 在config.xml中注册这个映射文件  

 

<mapper resource=" com/atguigu/ibatis/bean/userMapper.xml"/>

 3). 在dao中调用:

public User getUserById(int id) {
	SqlSession session = sessionFactory.openSession();
	User user = session.selectOne(URI+".selectUser", id);
	return user;
}

 3.2. 注解的实现

 1). 定义sql映射的接口

public interface UserMapper {
	@Insert("insert into users(name, age) values(#{name}, #{age})")
	public int insertUser(User user);

	@Delete("delete from users where id=#{id}")
	public int deleteUserById(int id);
			
	@Update("update users set name=#{name},age=#{age} where id=#{id}")
	public int updateUser(User user);

	@Select("select * from users where id=#{id}")
	public User getUserById(int id);

	@Select("select * from users")
	public List<User> getAllUser();
}

 2). 在config中注册这个映射接口

<mapper class="com.atguigu.ibatis.crud.ano.UserMapper"/>

       3) . 在dao类中调用

public User getUserById(int id) {
	SqlSession session = sessionFactory.openSession();
	UserMapper mapper = session.getMapper(UserMapper.class);
	User user = mapper.getUserById(id);
	return user;
}

 4. 几个可以优化的地方

4.1. 连接数据库的配置单独放在一个properties文件中

## db.properties

<properties resource="db.properties"/>

<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />

 

4.2. 为实体类定义别名,简化sql映射xml文件中的引用

<typeAliases>
	<typeAlias type="com.atguigu.ibatis.bean.User" alias="_User"/>
</typeAliases>

  4.3. 可以在src下加入log4j的配置文件,打印日志信息

1. 添加jar:

         log4j-1.2.16.jar

 

2.1. log4j.properties(方式一)

 

         log4j.properties

         log4j.rootLogger=DEBUG, Console

         #Console

         log4j.appender.Console=org.apache.log4j.ConsoleAppender

         log4j.appender.Console.layout=org.apache.log4j.PatternLayout

         log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n

         log4j.logger.java.sql.ResultSet=INFO

         log4j.logger.org.apache=INFO

         log4j.logger.java.sql.Connection=DEBUG

         log4j.logger.java.sql.Statement=DEBUG

         log4j.logger.java.sql.PreparedStatement=DEBUG

 

2.2. log4j.xml(方式二)

 

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

         <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">

                   <layout class="org.apache.log4j.PatternLayout">

                            <param name="ConversionPattern"

                                     value="%-5p %d{MM-dd HH:mm:ss,SSS} %m  (%F:%L) \n" />

                   </layout>

         </appender>

         <logger name="java.sql">

                   <level value="debug" />

         </logger>

         <logger name="org.apache.ibatis">

                   <level value="debug" />

         </logger>

         <root>

                   <level value="debug" />

                   <appender-ref ref="STDOUT" />

         </root>

</log4j:configuration>

 

 5. 解决字段名与实体类属性名不相同的冲突

5.1. 准备表和数据:

CREATE TABLE orders(
	order_id INT PRIMARY KEY AUTO_INCREMENT,
	order_no VARCHAR(20), 
	order_price FLOAT
);
INSERT INTO orders(order_no, order_price) VALUES('aaaa', 23);
INSERT INTO orders(order_no, order_price) VALUES('bbbb', 33);
INSERT INTO orders(order_no, order_price) VALUES('cccc', 22);

 

5.2. 定义实体类:

public class Order {
	private int id;
	private String orderNo;
	private float price;
}

 

5.3. 实现getOrderById(id)的查询:

方式一: 通过在sql语句中定义别名

<select id="selectOrder" parameterType="int" resultType="_Order">

         select order_id id, order_no orderNo,order_price price from orders where order_id=#{id}

</select>

                  

方式二: 通过<resultMap>

<select id="selectOrderResultMap" parameterType="int" resultMap="orderResultMap">

         select * from orders where order_id=#{id}

</select>

 

<resultMaptype="_Order" id="orderResultMap">

         <id property="id" column="order_id"/>

         <result property="orderNo" column="order_no"/>

         <result property="price" column="order_price"/>

</resultMap>

 

分享到:
评论

相关推荐

    spring集成 tk.mybatis插件

    使用tk.mybatis,你可以创建一个通用的Mapper接口,继承自`tk.mybatis.mapper.common.BaseMapper`,并指定实体类和对应的表名。例如: ```java public interface UserMapper extends BaseMapper&lt;User&gt; { } ```...

    Spring Boot整合tk.mybatis代码实例

    本文主要介绍了Spring Boot如何整合tk.mybatis的代码实例,旨在帮助读者更好地理解和应用tk.mybatis框架。下面将对本文中涉及的知识点进行详细的解释和分析。 1. tk.mybatis简介 tk.mybatis是一个基于MyBatis框架...

    mybatis.docx

    - MyBatis的主要目标是简化JDBC的使用,通过提供一套简单的API,使得开发者能够更专注于SQL本身,而不是JDBC的底层细节。 - 它消除了手动打开和关闭连接、预编译SQL语句、设置参数和获取结果集等步骤,提高了开发...

    mybatis3--2.mybatis开发dao

    MyBatis 可以使用简单的 XML 或注解进行配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 在 MyBatis 中,DAO(Data Access Object)层是与数据库交互的...

    springboot多数据源、整合mybatis的映射xml例子.zip

    通过自动配置和起步依赖,它使得创建独立的、生产级别的基于Spring的应用变得极其简单。 2. **多数据源配置**:在Spring Boot中,可以通过`@ConfigurationProperties`注解来读取配置文件中的多数据源信息。通常我们...

    mybatis开发使用的jar包

    下面将详细介绍MyBatis的关键知识点以及在SSM框架中的作用。 1. MyBatis核心组件: - SqlSessionFactory:它是MyBatis的核心,用于创建SqlSession对象,SqlSession是与数据库交互的接口。 - Configuration:配置...

    Mybatis Generator eclipse 插件

    下面将详细介绍如何在Eclipse中安装和使用Mybatis Generator插件。 首先,我们需要获取Mybatis Generator的插件文件。通常,这是一个.jar文件,可能命名为"MybatisGeneratorPlugin.jar"。这个文件可以在Mybatis ...

    MyBatis学习资料

    3. MyBatis的拦截器:如何使用和编写自定义拦截器,以实现特定的功能或优化。 4. MyBatis与Spring的集成:如何配置Spring的DataSource、SqlSessionFactoryBean等,以及使用MyBatis的Spring支持。 5. MyBatis的最佳...

    深入浅出MyBatis技术原理与实战.pdf.7z

    MyBatis是一款优秀的持久层框架,它简化了Java开发中数据库操作的复杂性,提供了灵活的SQL映射机制和简单的缓存策略。MyBatis的主要特点包括: 1. SQL动态映射:MyBatis允许开发者在XML或注解中编写SQL语句,提供了...

    Static Site Generators

    在本书《Static Site Generators》中,作者Brian Rinaldi探讨了现代静态网站生成工具的使用方法,并对当前流行的一些静态网站生成器进行了介绍。这些包括Jekyll、Wintersmith和Hugo等。这些工具各有特色,如Jekyll是...

    mybatis-spring-1.3.1.jar下载

    下面将详细介绍MyBatis-Spring的主要功能、工作原理以及如何与MyBatis-3.4.4等版本配合使用。 MyBatis-Spring的主要功能: 1. **自动扫描与配置**:MyBatis-Spring能够自动扫描项目中的Mapper接口,并根据这些接口...

    mybatis demo mybatis 实例

    MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 标题“mybatis demo mybatis 实例”指的是一个MyBatis的学习示例项目,...

    mybatis_generator使用手册

    该手册将详细介绍 MyBatis Generator 的安装、配置、使用等方面的内容。 2. 术语定义 * MyBatis Generator:MyBatis 的代码生成工具 * MyBatis:一个基于 Java 的持久层框架 * DAO:Data Access Object,数据访问...

    Mybatis讲义.pdf

    Mybatis的使用和特点 Mybatis可以配置为全XML配置,也可以采用注解的方式。它遵循了“约定优于配置”的原则,因此许多时候,其配置都遵循一定的默认规则,减少了配置的复杂性。 Mybatis有以下几个显著特点: - ...

    mybatis的讲课笔记, 包含mybatis的缓存,配置等

    MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 #### 2. MyBatis的配置文件 MyBatis 配置文件是 MyBatis 最重要...

    maven中的mybatis依赖

    MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects)映射成数据库中的记录。 #### Maven简介 Maven是Apache下的一个开源项目,是一个项目管理和综合工具。通过一个...

    mybatis-plus及分布式项目简介1

    在本文中,我们将深入探讨如何在分布式项目中使用Mybatis-Plus,以及它如何简化数据库操作。首先,我们从Spring与Mybatis-Plus的整合开始。 **1. Spring整合Mybatis-Plus** 在整合Mybatis-Plus到Spring项目时,...

    尚硅谷_MyBatis.pdf

    相比于传统的JDBC编程方式,MyBatis通过简单的XML或注解来配置和映射接口及Java的POJO对象到数据库中的记录,从而避免了大量的JDBC代码编写工作。这使得开发人员能够更加专注于业务逻辑的实现,而不需要过多地关心...

    Mybatis Jar包

    在文档的GettingStarted部分,Mybatis介绍了如何安装和配置Mybatis,以确保Mybatis能够正确运行。安装Mybatis很简单,只需要将mybatis-x.x.x.jar文件包含在类路径中即可。如果你使用Maven作为构建工具,那么可以添加...

    mybatis的jar包

    MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 标题中的"mybatis的jar包"指的是MyBatis框架的核心库文件,通常包含以下...

Global site tag (gtag.js) - Google Analytics