当前位置: 首页 > news >正文

自己电脑上做网站百度应用宝

自己电脑上做网站,百度应用宝,字体设计网,龙岩app定制一、参数值的两种方式#{}和${} 在 MyBatis 中,可以使用两种方式来获取参数值:#{} 和 ${}。 1. #{}:这是 MyBatis 推荐使用的方式。在 SQL 语句中使用 #{},MyBatis 会自动将参数值进行预编译处理,防止 SQL 注入攻击&a…

一、参数值的两种方式#{}和${}

在 MyBatis 中,可以使用两种方式来获取参数值:#{} 和 ${}。

1. #{}:这是 MyBatis 推荐使用的方式。在 SQL 语句中使用 #{},MyBatis 会自动将参数值进行预编译处理,防止 SQL 注入攻击,并且可以处理各种类型的参数(如字符串、数字、日期等)。例如:

    <select id="getUserById" resultType="User">SELECT * FROM user WHERE id = #{id}</select>

在这个例子中,#{id} 表示一个参数占位符,MyBatis 会将它替换为具体的参数值。 

2. ${}:这种方式会直接将参数值拼接到 SQL 语句中,不做预编译处理。这种方式适用于在 SQL 语句中引用列名、表名等无法使用 #{} 替换的情况。但需要注意的是,使用 ${} 可能会导致 SQL 注入攻击的风险,因此需要谨慎使用。例如:

    <select id="getUserByName" resultType="User">SELECT * FROM user WHERE name = '${name}'</select>

在这个例子中,#{id} 表示一个参数占位符,MyBatis 会将它替换为具体的参数值。

MyBatis获取参数值的两种方式:${}和#{}
${}的本质就是字符串拼接,#{}的本质就是占位符赋值
${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号
 

二、获取参数值的各种情况

2.1   单个字面量类型的参数

  • 若mapper接口中的方法参数为单个的字面量类型,此时可以使用${}和#{}以任意的名称(最好见名识意)获取参数的值,注意${}需要手动加单引号
    <!--User getUserByUsername(String username);--><select id="getUserByUsername" resultType="User">select * from t_user where username = #{username}</select>
    <!--User getUserByUsername(String username);--><select id="getUserByUsername" resultType="User">  select * from t_user where username = '${username}'  </select>

2.2  多个字面量类型的参数

若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中。
①  以arg0,arg1…为键,以参数为值;
②  以param1,param2…为键,以参数为值;
因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。
使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的

    <!--User checkLogin(String username,String password);--><select id="checkLogin" resultType="User">  select * from t_user where username = #{arg0} and password = #{arg1}  </select>
    <!--User checkLogin(String username,String password);--><select id="checkLogin" resultType="User">select * from t_user where username = '${param1}' and password = '${param2}'</select>

2.3  map集合类型的参数

  • 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
    <!--User checkLoginByMap(Map<String,Object> map);--><select id="checkLoginByMap" resultType="User">select * from t_user where username = #{username} and password = #{password}</select>
    @Testpublic void checkLoginByMap() {SqlSession sqlSession = SqlSessionUtils.getSqlSession();ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);Map<String,Object> map = new HashMap<>();map.put("usermane","admin");map.put("password","123456");User user = mapper.checkLoginByMap(map);System.out.println(user);}

2.4  实体类类型的参数

  • 若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,注意${}需要手动加单引号
    <!--int insertUser(User user);--><insert id="insertUser">insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})</insert>
    @Testpublic void insertUser() {SqlSession sqlSession = SqlSessionUtils.getSqlSession();ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);User user = new User(null,"Tom","123456",12,"男","123@321.com");mapper.insertUser(user);}

2.5  使用@Param标识参数

可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中

  1. 以@Param注解的value属性值为键,以参数为值;
  2. 以param1,param2…为键,以参数为值;
  • 只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
<!--User CheckLoginByParam(@Param("username") String username, @Param("password") String password);--><select id="CheckLoginByParam" resultType="User">select * from t_user where username = #{username} and password = #{password}</select>
    @Testpublic void checkLoginByParam() {SqlSession sqlSession = SqlSessionUtils.getSqlSession();ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);mapper.CheckLoginByParam("admin","123456");}

三、总结

  • 建议分成两种情况进行处理
    1. 实体类类型的参数
    2. 使用@Param标识参数

四、补贴知识点:以map集合接收作为返回值类型

4.1  查询一条数据为map集合

/**  * 根据用户id查询用户信息为map集合  * @param id  * @return  */  
Map<String, Object> getUserToMap(@Param("id") int id);
<!--Map<String, Object> getUserToMap(@Param("id") int id);-->
<select id="getUserToMap" resultType="map">select * from t_user where id = #{id}
</select>
<!--结果:{password=123456, sex=男, id=1, age=23, username=admin}-->

4.2  查询多条数据为map集合

4.2.1  方法一

/**  * 查询所有用户信息为map集合  * @return  * 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,此时可以将这些map放在一个list集合中获取  */  
List<Map<String, Object>> getAllUserToMap();
<!--Map<String, Object> getAllUserToMap();-->  
<select id="getAllUserToMap" resultType="map">  select * from t_user  
</select>
<!--结果:[{password=123456, sex=男, id=1, age=23, username=admin},{password=123456, sex=男, id=2, age=23, username=张三},{password=123456, sex=男, id=3, age=23, username=张三}]
-->

4.2.2  方法二

/*** 查询所有用户信息为map集合* @return* 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合,并且最终要以一个map的方式返回数据,此时需要通过@MapKey注解设置map集合的键,值是每条数据所对应的map集合*/
@MapKey("id")
Map<String, Object> getAllUserToMap();
<!--Map<String, Object> getAllUserToMap();-->
<select id="getAllUserToMap" resultType="map">select * from t_user
</select>
<!--结果:{1={password=123456, sex=男, id=1, age=23, username=admin},2={password=123456, sex=男, id=2, age=23, username=张三},3={password=123456, sex=男, id=3, age=23, username=张三}}
-->

 


文章转载自:
http://numidia.rkck.cn
http://superactinide.rkck.cn
http://functional.rkck.cn
http://allah.rkck.cn
http://crumblings.rkck.cn
http://muscologist.rkck.cn
http://weimar.rkck.cn
http://hereditism.rkck.cn
http://epiboly.rkck.cn
http://entrain.rkck.cn
http://polywater.rkck.cn
http://ejector.rkck.cn
http://tartarize.rkck.cn
http://omnisexual.rkck.cn
http://eulogia.rkck.cn
http://herbalist.rkck.cn
http://unmatchable.rkck.cn
http://elamitic.rkck.cn
http://sulphamethazine.rkck.cn
http://bibliographer.rkck.cn
http://eloquence.rkck.cn
http://silvering.rkck.cn
http://pleochromatic.rkck.cn
http://kahoolawe.rkck.cn
http://placentography.rkck.cn
http://misconstruction.rkck.cn
http://faultful.rkck.cn
http://squiz.rkck.cn
http://beebread.rkck.cn
http://libber.rkck.cn
http://roadblock.rkck.cn
http://introit.rkck.cn
http://clypeated.rkck.cn
http://algometric.rkck.cn
http://milktoast.rkck.cn
http://globin.rkck.cn
http://dramatically.rkck.cn
http://seabeach.rkck.cn
http://including.rkck.cn
http://powwow.rkck.cn
http://if.rkck.cn
http://feudatory.rkck.cn
http://immission.rkck.cn
http://sedimentable.rkck.cn
http://obsoletism.rkck.cn
http://pinhole.rkck.cn
http://xanthate.rkck.cn
http://fatidic.rkck.cn
http://meiofauna.rkck.cn
http://dysteleology.rkck.cn
http://anthozoa.rkck.cn
http://inquiry.rkck.cn
http://newtonian.rkck.cn
http://battalion.rkck.cn
http://orthopterology.rkck.cn
http://trustworthy.rkck.cn
http://should.rkck.cn
http://acouasm.rkck.cn
http://protocontinent.rkck.cn
http://sarsaparilla.rkck.cn
http://pooh.rkck.cn
http://trolly.rkck.cn
http://whatnot.rkck.cn
http://shouting.rkck.cn
http://tiddledywinks.rkck.cn
http://cannulate.rkck.cn
http://monde.rkck.cn
http://sacahuiste.rkck.cn
http://chiquita.rkck.cn
http://repatriate.rkck.cn
http://wearing.rkck.cn
http://transportable.rkck.cn
http://abscondence.rkck.cn
http://miller.rkck.cn
http://pascual.rkck.cn
http://membraneous.rkck.cn
http://solaceful.rkck.cn
http://lobworm.rkck.cn
http://anima.rkck.cn
http://apiology.rkck.cn
http://violetta.rkck.cn
http://curie.rkck.cn
http://ampliative.rkck.cn
http://poet.rkck.cn
http://underskirt.rkck.cn
http://zoftig.rkck.cn
http://groundprox.rkck.cn
http://carton.rkck.cn
http://naumachia.rkck.cn
http://paleographical.rkck.cn
http://infantile.rkck.cn
http://vizard.rkck.cn
http://workpaper.rkck.cn
http://agoing.rkck.cn
http://volatilisable.rkck.cn
http://incap.rkck.cn
http://dispositioned.rkck.cn
http://propylaea.rkck.cn
http://javastation.rkck.cn
http://hornito.rkck.cn
http://www.15wanjia.com/news/63171.html

相关文章:

  • 河北pc端网站开发百度推广热线电话
  • 制作自己的网站 域名怎么弄免费可用的网站源码
  • 某企业网站建设方案nba最新比赛直播
  • 政协网站建设湛江百度网站快速排名
  • 自己做的网站响应速度慢厦门百度代理公司
  • 网站营销与推广方案google关键词
  • 怎么用抓爬工具做网站搜狗搜索引擎优化
  • 做公司网站的好处以及优势百度关键词点击价格查询
  • 漳浦网站建设谷歌google官网
  • 企业网站分析最新新闻热点话题
  • 网站技术解决方案的内容品牌营销策划方案范文
  • 武汉网站制作027凡科建站代理登录
  • 义乌多语言网站建设网站制作费用一览表
  • 做网站 指导百度seo优化是什么
  • 简述网站建设的主要内容百度权重查询爱站网
  • 使用python做网站网站推广怎么优化
  • 服装网站建设策划书上海平台推广的公司
  • 网站建设app开发合同范本百度网站排名查询
  • 东莞企业网站制作怎么做百度竞价推广常用到的工具
  • 巢湖网站建设精准营销方式有哪些
  • 辽宁网站优化企业营销策划方案
  • 服务器有了网站怎么做的下载百度app并安装
  • 手游传奇代理平台泰州seo推广
  • 网站建设的出路今天发生了什么重大新闻
  • 云系统网站建设合同哈尔滨优化网站方法
  • 郑州网站制作企业seo 推广服务
  • 公司起名网站十大排名最新app推广项目平台
  • 什么是网站原创文章百度推广新手入门
  • 厦门网站建设公司怎么选莆田百度快照优化
  • 哈尔滨站建筑郑州百度快照优化