1.Mybatis介绍
MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.
2.mybatis快速入门
编写第一个基于mybaits的测试例子:
2.1. 添加jar包
【mybatis】 |
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> |
相关推荐
使用tk.mybatis,你可以创建一个通用的Mapper接口,继承自`tk.mybatis.mapper.common.BaseMapper`,并指定实体类和对应的表名。例如: ```java public interface UserMapper extends BaseMapper<User> { } ```...
本文主要介绍了Spring Boot如何整合tk.mybatis的代码实例,旨在帮助读者更好地理解和应用tk.mybatis框架。下面将对本文中涉及的知识点进行详细的解释和分析。 1. tk.mybatis简介 tk.mybatis是一个基于MyBatis框架...
- MyBatis的主要目标是简化JDBC的使用,通过提供一套简单的API,使得开发者能够更专注于SQL本身,而不是JDBC的底层细节。 - 它消除了手动打开和关闭连接、预编译SQL语句、设置参数和获取结果集等步骤,提高了开发...
MyBatis 可以使用简单的 XML 或注解进行配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 在 MyBatis 中,DAO(Data Access Object)层是与数据库交互的...
通过自动配置和起步依赖,它使得创建独立的、生产级别的基于Spring的应用变得极其简单。 2. **多数据源配置**:在Spring Boot中,可以通过`@ConfigurationProperties`注解来读取配置文件中的多数据源信息。通常我们...
下面将详细介绍MyBatis的关键知识点以及在SSM框架中的作用。 1. MyBatis核心组件: - SqlSessionFactory:它是MyBatis的核心,用于创建SqlSession对象,SqlSession是与数据库交互的接口。 - Configuration:配置...
下面将详细介绍如何在Eclipse中安装和使用Mybatis Generator插件。 首先,我们需要获取Mybatis Generator的插件文件。通常,这是一个.jar文件,可能命名为"MybatisGeneratorPlugin.jar"。这个文件可以在Mybatis ...
3. MyBatis的拦截器:如何使用和编写自定义拦截器,以实现特定的功能或优化。 4. MyBatis与Spring的集成:如何配置Spring的DataSource、SqlSessionFactoryBean等,以及使用MyBatis的Spring支持。 5. MyBatis的最佳...
MyBatis是一款优秀的持久层框架,它简化了Java开发中数据库操作的复杂性,提供了灵活的SQL映射机制和简单的缓存策略。MyBatis的主要特点包括: 1. SQL动态映射:MyBatis允许开发者在XML或注解中编写SQL语句,提供了...
在本书《Static Site Generators》中,作者Brian Rinaldi探讨了现代静态网站生成工具的使用方法,并对当前流行的一些静态网站生成器进行了介绍。这些包括Jekyll、Wintersmith和Hugo等。这些工具各有特色,如Jekyll是...
下面将详细介绍MyBatis-Spring的主要功能、工作原理以及如何与MyBatis-3.4.4等版本配合使用。 MyBatis-Spring的主要功能: 1. **自动扫描与配置**:MyBatis-Spring能够自动扫描项目中的Mapper接口,并根据这些接口...
MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 标题“mybatis demo mybatis 实例”指的是一个MyBatis的学习示例项目,...
该手册将详细介绍 MyBatis Generator 的安装、配置、使用等方面的内容。 2. 术语定义 * MyBatis Generator:MyBatis 的代码生成工具 * MyBatis:一个基于 Java 的持久层框架 * DAO:Data Access Object,数据访问...
Mybatis的使用和特点 Mybatis可以配置为全XML配置,也可以采用注解的方式。它遵循了“约定优于配置”的原则,因此许多时候,其配置都遵循一定的默认规则,减少了配置的复杂性。 Mybatis有以下几个显著特点: - ...
MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 #### 2. MyBatis的配置文件 MyBatis 配置文件是 MyBatis 最重要...
MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects)映射成数据库中的记录。 #### Maven简介 Maven是Apache下的一个开源项目,是一个项目管理和综合工具。通过一个...
在本文中,我们将深入探讨如何在分布式项目中使用Mybatis-Plus,以及它如何简化数据库操作。首先,我们从Spring与Mybatis-Plus的整合开始。 **1. Spring整合Mybatis-Plus** 在整合Mybatis-Plus到Spring项目时,...
相比于传统的JDBC编程方式,MyBatis通过简单的XML或注解来配置和映射接口及Java的POJO对象到数据库中的记录,从而避免了大量的JDBC代码编写工作。这使得开发人员能够更加专注于业务逻辑的实现,而不需要过多地关心...
在文档的GettingStarted部分,Mybatis介绍了如何安装和配置Mybatis,以确保Mybatis能够正确运行。安装Mybatis很简单,只需要将mybatis-x.x.x.jar文件包含在类路径中即可。如果你使用Maven作为构建工具,那么可以添加...
MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 标题中的"mybatis的jar包"指的是MyBatis框架的核心库文件,通常包含以下...