#{}和${} 区别

一:概述

1.#{}是不能写到字符串中的,如果写到字符串表达字串内容一部分。Mybatis是无法给这个占位符赋值。

${}是可以写到字符串中的,表达取${}中表描述的字段的值。

2.#{} 占位符使用jdbc的预编译处理,可以有防止sql注入。

${}表示取字符的值,有sql注入的可能。

对于模糊查询来讲,如果在映射文件中不使用字符中,使用#{}

二:实例

共有的dao层的接口

1.#{}

@Test
    public void testGetPersonByLikeName() {

        SqlSession session= MyBatisUtils.getSession();
        PersonDao personDao = session.getMapper(PersonDao.class);
        Person person=new Person();
        person.setName("王%");
        List<Person> personList= personDao.getPersonByLikeName(person);
        for (Person p : personList) {
            System.out.println(p);
        }
        session.commit();
        MyBatisUtils.close(session);
    }

2.${}

 对于模糊查询来讲,如果在映射文件中的sql语句中含有单引号,此时不能使用#{},只能使用${}

@Test
    public void testGetPersonByLikeName() {

        SqlSession session= MyBatisUtils.getSession();
        PersonDao personDao = session.getMapper(PersonDao.class);
        Person person=new Person();
        person.setName("王");
        List<Person> personList= personDao.getPersonByLikeName(person);
        for (Person p : personList) {
            System.out.println(p);
        }
        session.commit();
        MyBatisUtils.close(session);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值