mybatis模糊查询、分页和别名配置的方法

mybatis模糊查询(3种

第一种

select * from user where username like "%" #{name} "%"

第二种

select * from user where username like "%${value}%"

第三种

<!--concat拼接字符串 mysql独有的函数-->
select * from user where username like concat("%",#{username},"%")

全网都这样说,但具体怎实现注入,我也不知道怎么搞。

  • #{}是预编译处理,${}是字符串替换。 Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;
  • Mybatis在处理 $ {}时,就是把${}替换成变量的值。
  • 使用#{}可以有效的防止SQL注入,提高系统安全性。

配置别名(typeAliases)

第一种方式:在mybatis-config.xml核心配置文件中的<configuration></configuration>中添加:

<typeAlias type="com.lu.pojo.User" alias="User"/>

User可以用在任何使用 com.lu.pojo.User 的地方。

第二种方式:
也可以指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean,比如:

<typeAliases>
 <package name="com.lu.pojo"/>
</typeAliases>

在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。 比如com.lu.pojo.User 的别名为 user ;若有注解,则别名为其注解值。比如:

@Alias("user")
public class User{
 ...
}

属性名和字段名不一致问题

问题:数据库中密码是pwd表示,实体类中是password表示。查询结果会是null。

第一种方式:在sql语句中用as起别名。

<select id="getUserById" resultType="com.lu.pojo.User">
  select id,username, pwd as password from user where id = #{id}
 </select>

第二种方式: 使用 resultMap进行映射。

<!--结果集映射-->
 <resultMap id="userMap" type="com.lu.pojo.User">
  <!--property是实体类中的属性,column是数据库中的字段 -->
  <result property="password" column="pwd" />
 </resultMap>

 <select id="getUserById" resultMap="userMap">
  select id,username, pwd from user where id = #{id}
 </select>

分页查询的3种方式

1、通过limit实现分页

mapper接口:

//使用limit实现分页
 List<User> getUserByLimit(Map<String,Integer> map);

Mapper.xml中:

<select id="getUserByLimit" parameterType="map" resultType="com.lu.pojo.User">
  select * from user limit #{offset}, #{pageSize}
 </select>

测试方法:

@Test
 public void getUserByLimit(){
  SqlSession sqlSession = MybatisUtils.getSqlSession();
  UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

  Map<String, Integer> map = new HashMap<String, Integer>();
  map.put("offset",1);
  map.put("pageSize",2);
  List<User> users = userMapper.getUserByLimit(map);
  for (User user : users) {
   System.out.println(user);
  }
  sqlSession.close();
 }

2、通过RowBounds实现分页

mapper接口:

 //通过RowBounds实现分页
 List<User> getUserByRowBounds(RowBounds rowBounds);

Mapper.xml中:

<select id="getUserByRowBounds" resultType="com.lu.pojo.User">
  select * from user
 </select>

测试方法:

 @Test
 public void getUserByRowBounds(){
  SqlSession sqlSession = MybatisUtils.getSqlSession();
  UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

  RowBounds rowBounds = new RowBounds(1, 2);
  List<User> users = userMapper.getUserByRowBounds(rowBounds);

  for (User user : users) {
   System.out.println(user);
  }
  sqlSession.close();
 }

3、通过分页插件pagehelper实现分页

pom.xml中导入依赖:

 <dependency>
   <groupId>com.github.pagehelper</groupId>
   <artifactId>pagehelper</artifactId>
   <version>4.1.6</version>
  </dependency>

mybatis-config.xml核心配置文件中添加:

<plugins>
  <plugin interceptor="com.github.pagehelper.PageHelper">
    <property name="dialect" value="mysql"/>
  </plugin>
</plugins>

mapper:

 //通过pagehelper分页插件实现
  List<User> getUserByPageHelper();

mapper.xml:

 <select id="getUserByPageHelper" resultType="com.lu.pojo.User">
    select * from user
  </select>

测试方法:

在类最上边先import,否则PageHelper不能用

import com.github.pagehelper.PageHelper;

再写测试类:

 @Test
  public void getUserByPageHelper(){
    SqlSession sqlSession = MybatisUtils.getSqlSession();
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

    PageHelper.startPage(1,3);
    List<User> users = userMapper.getUserByPageHelper();
    for (User user : users) {
      System.out.println(user);
    }
    sqlSession.close();
  }

使用Lombok步骤

1、在IDEA中安装Lombok插件。

点击左上角的 File —> 点击 Settings —> 选择 Pulgins —> 输入 Lombok 搜索—> 点击 Install 进行安装。如下图

2、在项目中导入lombok的jar包

<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <version>1.18.12</version>
  <scope>provided</scope>
</dependency>

3、在实体类中添加注解

@NoArgsConstructor:生成无参构造器;

@AllArgsConstructor:生成全参构造器;

@Data:作用于类上,是以下注解的集合:

@ToString @EqualsAndHashCode @Getter @Setter @RequiredArgsConstructor

到此这篇关于mybatis模糊查询、分页和别名配置的文章就介绍到这了,更多相关mybatis模糊查询、分页和别名配置内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • SpringBoot 使用Mybatis分页插件实现详解

    这篇文章主要介绍了SpringBoot 使用Mybatis分页插件实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.导入分页插件包和jpa包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </depende

  • MyBatis实现动态查询、模糊查询功能

    要实现查询,咱们就先有个数据库,截图如下,其中cityAreaId是外键,本次可以忽略: 下面Branches是我的实体类,里面有name和address属性: 接口中方法: public List<Branches> finDongTai(@Param("name")String name,@Param("add")String address);//动态 public List<Branches> findLike(@Param(&quo

  • MyBatis实现模糊查询的几种方式

    在学习MyBatis过程中想实现模糊查询,可惜失败了.后来上百度上查了一下,算是解决了.记录一下MyBatis实现模糊查询的几种方式. 数据库表名为test_student,初始化了几条记录,如图: 起初我在MyBatis的mapper文件中是这样写的: <select id="searchStudents" resultType="com.example.entity.StudentEntity" parameterType="com.exampl

  • Mybatis 中 Oracle 的拼接模糊查询及用法详解

    一.结论 这里先给大家看一下结论 Oracle 中,拼接模糊查询的正确写法 SELECT A.USER_ID, A.USER_NAME FROM USER A AND A.USER_NAME like concat(concat('%','w'),'%') 或者 AND A.USER_NAME like '%' || 'w' || '%' Mybatis 中,拼接模糊查询的正确写法 <select id="selectByName" resultMap="BaseRes

  • 详解MyBatis模糊查询LIKE的三种方式

    模糊查询也是数据库SQL中使用频率很高的SQL语句,使用MyBatis来进行更加灵活的模糊查询. 直接传参法 直接传参法,就是将要查询的关键字keyword,在代码中拼接好要查询的格式,如%keyword%,然后直接作为参数传入mapper.xml的映射文件中. public void selectBykeyWord(String keyword) { String id = "%" + keyword + "%"; String roleType = "

  • mybatis模糊查询、分页和别名配置的方法

    mybatis模糊查询(3种) 第一种 select * from user where username like "%" #{name} "%" 第二种 select * from user where username like "%${value}%" 第三种 <!--concat拼接字符串 mysql独有的函数--> select * from user where username like concat("%&

  • Mybatis模糊查询及自动映射实现详解

    这篇文章主要介绍了Mybatis模糊查询及自动映射实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Mybatis的模糊查询 1. 参数中直接加入%% 1 2 3 4 5 6 7 8 9 param.setUsername("%CD%"); param.setPassword("%11%"); <select id="selectPersons" resultType="p

  • mybatis 模糊查询的实现方法

    mybatis 模糊查询的实现方法 mybatis的逆向助手确实好用,可以省去很多编写常规sql语句的时间,但是它没办法自动生成模糊查询语句,但开发中模糊查询是必不可少的,所以,需要手动对mapper编写模糊查询功能. 这里先明确MyBatis/Ibatis中#和$的区别: 1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111", 如果传入的值是id,则解

  • Mybatis模糊查询和动态sql语句的用法

    Mybatis 模糊查询和动态sql语句 模糊查询 对数据库最常用的操作就是查询了,但是如何使用Mybatis进行模糊查询呢?下面先看一个简单的模糊查询 <select id="select01" resultMap="BasicResultMap"> SELECT * FROM oa_employee WHERE emp_name LIKE #{asd} </select> 这是一条伪模糊查询, 因为没有实现真正的模糊 "%&qu

  • mybatis模糊查询之bind标签和concat函数用法详解

    1.二种方式都可以用来模糊查询,都能预防 SQL 注入.但是在更换数据库情况下,bind标签通用. <if test=" userName != null and userName !=""> and userName like concat('%' ,#{userName},'%') </if> 2.使用concat函数连接字符串,在mysql中这个函数支持多个参数,但是在oracle中这个函数只支持2个参数,由于不同数据库之间的语法差异,更换数据库

  • yum安装模糊查询所需要的软件包的方法(推荐)

    yum安装卸载命令, yum install 'package_name' yum remove 'package_name' yum查询想要安装的包 yum search 'keyword' 例如yum search messenger 模糊搜索本地yum包 yum list | grep packageName 列出所有可安装的软件包 yum list 列出所有可更新的软件包 yum list updates 列出所有已安装的软件包 yum list installed 列出所有已经安装但不

  • mysql一对多关联查询分页错误问题的解决方法

    xml问价中查询数据中包含list,需要使用collection <resultMap id="XX" type="com.XXX.XXXX"> <id column="o_id" jdbcType="BIGINT" property="id" /> <result column="o_user_id" jdbcType="BIGINT"

  • mybatis的动态SQL和模糊查询实例详解

    现在以一个例子来介绍mybatis的动态SQL和模糊查询:通过多条件查询用户记录,条件为姓名模糊匹配,并且年龄在某两个值之间. 新建表d_user: create table d_user( id int primary key auto_increment, name varchar(10), age int(3) ); insert into d_user(name,age) values('Tom',12); insert into d_user(name,age) values('Bob

  • Mybatis CURD及模糊查询功能的实现

    命名空间namespace: 配置文件中namespace中的名称为对应Mapper接口或者Dao接口的完整包名,必须一致! 1.查询(select) select: 接口中的方法名与映射文件中的SQL语句ID 一一对应 id parameterType resultType 案例:根据id查询用户 1.写接口(在UserMapper中添加对应的方法) public interface UserMapper { //根据ID查询用户 User getuserByID(int id); } 2.U

随机推荐