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

福州产品网页制作的公司优化关键词排名的工具

福州产品网页制作的公司,优化关键词排名的工具,华为十大外包公司排名,个人微企业网站模板一、参数值的两种方式#{}和${} 在 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://www.15wanjia.com/news/26911.html

相关文章:

  • 安徽阜阳网站建设专业网站建设公司首选
  • 拖拽网站怎么做的盐酸达泊西汀片是治疗什么的药物
  • h5页面制作素材黑帽seo是作弊手法
  • 银川做企业网站湘潭关键词优化公司
  • wordpress 父级页面百度搜索引擎优化公司哪家强
  • 全国建设工程造价管理系统惠州seo排名优化
  • 自己如何建设网站公司网站首页设计
  • 手机版网站建设小程序
  • 网站建设的制度建设网站推广的主要方法
  • 做优惠券网站要多少钱爱站网长尾关键词挖掘工具下载
  • 自适应网站是什么企业在线培训平台
  • 企业网站做留言板有什么优势地推拉新接单平台
  • 大城网站制作seo网络优化推广
  • 贵州建网站报价各大网站的网址
  • 设计网站的素材网址大全123
  • 在线直播硬件优化大师下载
  • 阿里云esc建设网站seo网站推广软件 快排
  • 炫酷网站推荐先做后付费的代运营
  • 网站过场动画灰色行业推广
  • 做网站会遇到什么问题网页代码模板
  • 网站推广包年网络推广外包费用
  • 网站的seo关键词歌词表达的意思
  • 中国风html5网站模板百度域名收录提交入口
  • 淘宝的网站建设怎么建重庆网站seo外包
  • 开广告公司利润大吗seo营销课程培训
  • 找外包做网站要多久百度竞价什么意思
  • 威海网站建设哪家好网络营销公司全网推广公司
  • 网站虚拟主机里的内容强制删除佛山网站优化
  • 网站增加一体化建设功能的好处百度竞价排名规则
  • 工商注册代理优化方案模板