第一个Mybatis程序

核心配置文件mybatis-config.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.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/db4?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/dao/UserMapper.xml"/>
</mappers>
</configuration>

编写mybatis工具类

public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory; static {
try {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
} public static SqlSession getSqlSession() {
return sqlSessionFactory.openSession();
}
}

编写代码

  • 实体类User
public class User {
private int id;
private String username;
private String password;
}
//重写方法toString方法等
  • Dao接口UserMapper.java
public interface UserMapper {
List<User> getUserList();
}
  • 接口实现类Mapper配置文件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.dao.UserMapper">
<select id="getUserList" resultType="com.pojo.User">
select * from db4.user
</select>
</mapper>
  • test类
public class test {
@Test
public void test1(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List<User> userList = userMapper.getUserList(); for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
}
  • 约定大于配置
<build>
<resources>
<resource>
<directory>src/main/resources/</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource> <resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource> </resources>
</build>

CRUD

  • 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.dao.UserMapper">
<select id="getUserList" resultType="com.pojo.User">
select *
from db4.user
</select> <select id="getUserById" parameterType="int" resultType="com.pojo.User">
select *
from db4.user
where id = #{id}
</select> <select id="addUser" parameterType="com.pojo.User">
insert into db4.user (id, username, password)
values (#{id}, #{username}, #{password})
</select> <select id="updateUser" parameterType="com.pojo.User">
update db4.user
set username = #{username},
password = #{password}
where id = #{id};
</select> <select id="deleteUser" parameterType="int">
delete
from db4.user
where id = #{id}
</select>
</mapper>
  • UserMapper.java
public interface UserMapper {
List<User> getUserList(); User getUserById(int id); void addUser(User user); void updateUser(User user); void deleteUser(int id);
}
  • test.java
public class test {
@Test
public void getUserList_test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List<User> userList = userMapper.getUserList(); for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
} @Test
public void getUserById_test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(1);
System.out.println(user);
sqlSession.close();
} @Test
public void addUser_test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
userMapper.addUser(new User(66,"zhang", "7777"));
sqlSession.commit();
sqlSession.close();
} @Test
public void updateUser_test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
userMapper.updateUser(new User(2,"oooo", "000000"));
sqlSession.commit();
sqlSession.close();
} @Test
public void deleteUser_test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
userMapper.deleteUser(10);
sqlSession.commit();
sqlSession.close();
}
}

万能的Map查询

  • Map被用为构造器
User getUserByMapId(Map map);
<select id="getUserByMapId" parameterType="map" resultType="com.pojo.User">
select *
from db4.user
where id = #{mapId}
</select>
@Test
public void getUserByMapId_test() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
Map<String, Object> map = new HashMap<>();
map.put("mapId", 1);
User user = userMapper.getUserByMapId(map);
System.out.println(user);
sqlSession.commit();
sqlSession.close();
}

模糊查询怎么写

  • java执行代码的时候,使用通配符% %
List<User> userlist = mapper.getUserLike("%张%");
  • 在sql拼接中使用通配符!
select * from db4.user where name like "%"#{value}"%"

最新文章

  1. Intel 推出 DPDK 开发包的意义是什么?
  2. 使用scala开发spark入门总结
  3. 16 BasicHashTable基本哈希表类(三)——Live555源码阅读(一)基本组件类
  4. visual studio 局域网远程调试web项目
  5. UINavigationController 子控制器管理原理
  6. C#程序集编译输出XML文档的作用
  7. MySQL 当记录不存在时插入(insert if not exists)
  8. 自己实现的简单MVC框架(类似Struts2+Spring)
  9. UVALive 6869(后缀数组)
  10. hdu_5742_It&#39;s All In The Mind
  11. BZOJ 4408: [Fjoi 2016]神秘数 [主席树]
  12. 小小知识点(六)——算法中的P问题、NP问题、NP完全问题和NP难问题
  13. Django的model form组件
  14. 神烦之float
  15. iOS 渐变提示。错误弹出提示 几秒自动消失
  16. Python学习之旅(二十九)
  17. 原生js 数组的迭代的方法
  18. orcl 之 导入和导出(2)
  19. 深入浅出php socket编程
  20. 鼠标移上去触动hover致使div向上移动几个相素(动画transition轻轻的移动)

热门文章

  1. 二、mycat15种分片规则
  2. @RequestMapping 注解有什么用?
  3. Java 中 ++ 操作符是线程安全的吗?
  4. google fonts 国内使用解决方案
  5. [护网杯 2018]easy_tornado 1
  6. 浅谈arguments属性callee
  7. (ICONIP2021)On the Unreasonable Effectiveness of Centroids in Image
  8. Python接口自动化——文件上传/下载接口
  9. Python入门-import导入模块功能
  10. OllyDbg---数学指令