Mybatis_HelloWorld
【梗概】
1.根据XML配置文件(全局配置文件,有数据源的一些运行信息)创建一个SqlSessionFactory对象。
2.sql映射文件:配置了每一个sql以及sql的封装规则。
3.将sql映射文件注册在全局配置文件中。
4写代码:
(1)根据全局配置文件得到SqlSessionFactory。
(2)使用SqlSession工厂,得到sqlSession对象,使用它进行增删改查。一个sqlSession就是代表和数据库的一次会话,用完关闭。
(3)使用sql的唯一标识来告诉Mybatis执行执行哪个sql。sql都保存在sql映射文件中。
【编写第一个基于Mybatis的程序】
(1)添加jar包
Mybatis:mybatis-3.1.1.jar
MySQL驱动包:mysql-connector-java-5.1.7-bin.jar
(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);
(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">
6 <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>
(4) 定义表所对应的实体类
public class User {
private int id;
private String name;
private int age;
//get,set 方法
}
(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>
(6)在 在 conf.xml 文件中注册 userMapper.xml
<mappers>
<mapper resource="com/atguigu/mybatis_test/test1/userMapper.xml"/>
</mappers>
(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);
}
}
【操作 users 表的 CRUD】
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="net/lamp/java/ibatis/bean/userMapper.xml"/>
3). 在 在 dao 中调用:
public User getUserById(int id) {
SqlSession session = sessionFactory.openSession();
User user = session.selectOne(URI+".selectUser", id);
return user;
}
【注解的实现】
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;
}
【几个可以优化的地方】
(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}" />
(2)为实体类定义别名, 简化 sql 映射 xml 文件中的引用
<typeAliases>
<typeAlias type="com.atguigu.ibatis.bean.User" alias="_User"/>
</typeAliases>
(3)可以在 src 下加入 log4j 的配置文件, 打印日志信息
1. 添加 jar:
log4j-1.2.16.jar
2. 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
3.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>
最新文章
- iOS架构一个中型普通App的一些经验总结
- iOS开发资料链接
- 如何在Linux中查看所有正在运行的进程
- discuz 同步登录问题
- 【JavsScript】JavaScript MVC 框架技术选型
- AQL Subset Compiler:手把手教你如何写一个完整的编译器
- 《UNIX网络编程》之点对点通信
- 为Pythonic论坛添加一个“专题”功能(续)
- mongoDB &; Nodejs 访问mongoDB (二)
- C++ 窗口可改风格
- Linux Centos 6.5_x86安装Nginx
- Kindeditor JS 取值问题以及上传图片后回调等
- JAVA面向对象思想
- 删除项目中的.pyc文件
- Winform DevExpress控件库(二) 使用SplashScreenManager控件定制程序加载页面
- codeforces706E
- 一句话说清楚cache和buffer
- hdu-3671-tarjin/割点方案
- 【IIS错误】IIS各种错误
- [LeetCode] 285. Inorder Successor in BST_Medium tag: Inorder Traversal
热门文章
- python 匿名函数的使用(并没有那么简单)
- Fighting
- Arrays.asList()后调用add,remove这些method时出现java.lang.UnsupportedOperationException异常
- Android 内存溢出处理方案
- C# 判断文件和文件夹是否存在并创建
- D. Artsem and Saunders 数学题
- AJPFX解析Java关键字之assert
- Burp Suite集成sqlmap
- java格式化sql
- 2015年度精品 最新力作32位和64位xp,win7,win8,win10系统下载(电脑城专用版)