Mybatis的select查询的三种方式

Posted 北极的大企鹅

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis的select查询的三种方式相关的知识,希望对你有一定的参考价值。

1、首先建立一个测试的dao

1 public interface IStudentDao {
2 
3     // 根据姓名查询
4     List<Student> selectStudentsByName(String name);
5 }

2、对这个dao进行实现

 1 public class StudentDaoImpl implements IStudentDao {
 2 
 3     private SqlSession sqlSession;
 4 
 5     // 根据姓名查询
 6     public List<Student> selectStudentsByName(String name) {
 7         List<Student> students = null;
 8 
 9         try {
10             sqlSession = MybatisUtil.getSqlSession();
11             students = sqlSession.selectList("selectStudentsByName", name);
12         } catch (Exception e) {
13             e.printStackTrace();
14         } finally {
15             if (sqlSession != null) {
16                 sqlSession.close();
17             }
18         }
19         return students;
20     }
21 }

3、utils的书写

 1 public class MybatisUtil {
 2     private static SqlSessionFactory sqlSessionFactory;
 3 
 4     public static SqlSession getSqlSession() {
 5         try {
 6             if (sqlSessionFactory == null) {
 7                 // 读取配置文件
 8                 InputStream inputStream = Resources
 9                         .getResourceAsStream("Mybatis.xml");
10                 // 创建工厂
11                 sqlSessionFactory = new SqlSessionFactoryBuilder()
12                         .build(inputStream);
13             }
14         } catch (IOException e) {
15             e.printStackTrace();
16         }
17         return sqlSessionFactory.openSession();
18     }
19 }

4、配置文档

(1)Mybatis.xml

 1 <?xml version="1.0" encoding="UTF-8" ?>
 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
 3 "http://mybatis.org/dtd/mybatis-3-config.dtd">
 4 <configuration>
 5 
 6     <properties resource="jdbc.properties" />
 7 
 8     <!-- 别名标签 -->
 9     <typeAliases>
10         <typeAlias type="com.liuya.demo.mybaits.crud.pojo.Student"
11             alias="Student" />
12     </typeAliases>
13 
14     <!-- 配置运行的数据库环境 -->
15     <environments default="mysqlenvironment">
16         <environment id="mysqlenvironment">
17             <!-- 連接池在本地连接中使用,在SSM中不用,用C3P0和DBCP -->
18             <transactionManager type="JDBC" />
19             <dataSource type="POOLED">
20                 <property name="driver" value="${driver}" />
21                 <property name="url" value="${url}" />
22                 <property name="username" value="${username}" />
23                 <property name="password" value="${password}" />
24             </dataSource>
25         </environment>
26     </environments>
27 
28     <!-- 连接映射文件 -->
29     <mappers>
30         <!-- 最终使用的都是package -->
31         <mapper resource="com/liuya/demo/mybaits/crud/mapper/StudentMapper.xml" />
32     </mappers>
33 </configuration>

(2)properties的书写

#
##正式服务器
driver = com.mysql.jdbc.Driver
url = jdbc:mysql://127.0.0.1:3306/crud?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true
username = root
password = 123456

(3)mapper的书写

<?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="test">

    <!-- 根据姓氏模糊查询 -->
    <select id="selectStudentsByName" resultType="Student">
        select
        NAME,AGE,SCORE from STUDENT where NAME like concat (‘%‘,#{ooo},‘%‘)
    </select>


</mapper>

5、测试的书写

 1 public class MyTest {
 2 
 3     private IStudentDao idao;
 4 
 5     @Before
 6     public void before() {
 7         idao = new StudentDaoImpl();
 8     }
 9     // 根据name查询一个学生
10     @Test
11     public void testSelectStudentsByName() {
12         System.out.println("开始查询学生");
13         List<Student> students = idao.selectStudentsByName("张");
14         for (Student student : students) {
15             System.out.println(student);
16         }
17         System.out.println("查询学生成功");
18     }
19 }

这就是一个完整的select查询的书写,重点在于mapper中的select书写

        写法一(比较复杂):

<!-- 根据姓氏模糊查询 -->
    <select id="selectStudentsByName" resultType="Student">
        select
        NAME,AGE,SCORE from STUDENT where NAME like concat (‘%‘,#{ooo},‘%‘)
    </select>
写法二(一般使用的比较多):
<!-- 根据姓氏模糊查询 -->
    <select id="selectStudentsByName" resultType="Student">
        select
        NAME,AGE,SCORE from STUDENT where NAME like ‘%‘#{ooo}‘%‘
    </select>
写法三(不建议使用,会有sql注入问题和加载速度慢的问题):
<!-- 根据姓氏模糊查询 -->
    <select id="selectStudentsByName" resultType="Student">
        select
        NAME,AGE,SCORE from STUDENT where NAME like ‘%&{value}%‘
    </select>
like后的括号值,只能是value。




以上是关于Mybatis的select查询的三种方式的主要内容,如果未能解决你的问题,请参考以下文章

mybatis查询的三种方式

mybatis查询的三种方式

mybatis 模糊查询 like的三种方式

MyBatis学习笔记 —— 特殊SQL的执行

什么?mybatis-plus的多表查询,你还在写sql语句?!CRUD2多表联查的三种方式

MyBatis 延迟加载的三种加载方式深入,你get了吗?