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

最大的网站短网址生成怎么使用

最大的网站,短网址生成怎么使用,炫的手机网站,牡丹江网站seo5、MyBatis获取参数值的两种方式 MyBatis获取参数值的两种方式#xff1a;${} 和 #{} ${} 的本质就是字符串拼接#xff0c; #{} 的本质就是占位符赋值 ${} 使用字符串拼接的方式拼接sql#xff0c;若为字符串类型或日期类型的字段进行赋值时#xff0c;需要手动加单引号${} 和 #{} ${} 的本质就是字符串拼接 #{} 的本质就是占位符赋值 ${} 使用字符串拼接的方式拼接sql若为字符串类型或日期类型的字段进行赋值时需要手动加单引号但是#{}使用占位符赋值的方式拼接sql此时为字符串类型或日期类型的字段进行赋值时可以自动添加单引号 5.1、单个字面量类型的参数 若mapper接口中的方法参数为单个的字面量类型 此时可以使用 ${} 和 #{} 以任意的名称获取参数的值注意${} 需要手动加单引号 UserMapper.java package com.fan.mybatis.mapper;import com.fan.mybatis.pojo.User; /*** MyBatis获取参数值的两种方式#{} 和 ${}* #{}的本质是占位符${}的本质是字符串拼接* 1、若mapper接口方法的参数为单个的字面量类型* 此时可以通过#{} 和 ${}以任意的内容获取参数值一定要注意${}的单引号问题 */public interface UserMapper {/*** 根据用户名查询用户信息* param username* return*/User getUserByUsername(String username); }UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idgetUserByUsername resultTypeUserselect * from t_user where username #{username}/select /mapperParameterTest.java package com.fan.mybatis;import com.fan.mybatis.mapper.UserMapper; import com.fan.mybatis.pojo.User; import com.fan.mybatis.utils.SqlSessionUtils; import org.apache.ibatis.session.SqlSession; import org.junit.Test;public class ParameterTest {Testpublic void testGetUserByUsername(){SqlSession sqlSession SqlSessionUtils.getSqlSession();UserMapper mapper sqlSession.getMapper(UserMapper.class);User user mapper.getUserByUsername(admin);System.out.println(user);} }运行控制台打印输出如下 DEBUG 02-24 17:35:24,407 Preparing: select * from t_user where username ? (BaseJdbcLogger.java:137) DEBUG 02-24 17:35:24,426 Parameters: admin(String) (BaseJdbcLogger.java:137) DEBUG 02-24 17:35:24,442 Total: 1 (BaseJdbcLogger.java:137) User{id1, username‘admin’, password‘123456’, age23, gender‘男’, email‘12345qq.com’} 可以看到映射文件中的 #{} 变为? #{} 被当做占位符。传过来的参数是admin查询出来1条数据。 ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idgetUserByUsername resultTypeUserselect * from t_user where username #{name}/select /mapper将#{usenrame}变为#{name} , 运行可以看到查询出来的结果。 在mybatis传递参数的过程不知道传递的参数叫什么名字只知道传递的值是 admin所以传递参数值跟#{}里的参数名字没有关系。 建议#{}里的参数名字和传递的参数名一样。 ${}测试 错误写法${username} ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapper PUBLIC -//mybatis.org//DTD Mapper 3.0//EN http://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idgetUserByUsername resultTypeUser!--select * from t_user where username #{username}--select * from t_user where username ${username}/select /mapper可以看到 admin是一个字符串传入sql中没有加引号。不加单引号会被当做字段来解析 Unknown column ‘admin’ in ‘where clause’ where字句中有一个不认识的列/字段 admin #{}执行sql的时候占用的是; ${} 执行sql的时候是直接拼接在sql中的。 正确写法‘${usenrame}’ ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idgetUserByUsername resultTypeUser!--select * from t_user where username #{username}--select * from t_user where username ${username}/select /mapper${}里不能写数值纯数字是可以运算的。 5.2、多个字面量类型的参数 若mapper接口中的方法参数为多个时 此时MyBatis会自动将这些参数放在一个map集合中以arg0, arg1…为键以参数为值以param1, param2 … 为键以参数为值因此只需要通过${} 和 #{} 访问map集合的键就可以获取相应的值注意${} 需要手动加单引号 UserMapper.java package com.fan.mybatis.mapper;import com.fan.mybatis.pojo.User;/*** Date: 2023/02/24* Author: fan* Description:* MyBatis获取参数值的两种方式#{} 和 ${}* #{}的本质是占位符${}的本质是字符串拼接* 1、若mapper接口方法的参数为单个的字面量类型* 此时可以通过#{} 和 ${}以任意的内容获取参数值一定要注意${}的单引号问题* 2、若mapper接口的方法的参数为多个的字面量类型* 此时MyBatis会将参数放在map集合中以两种方式存储数据* a 以arg0,arg1,...为键以参数为值* b 以param1,param2,...为键以参数为值* 因此只需要通过#{}和${}访问map集合的键就可以获取相对应的值一定要注意${}的单引号问题*/ public interface UserMapper {/*** 验证登录* param username* param password* return*/User checkLogin(String username,String password); }UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idcheckLogin resultTypeUserselect * from t_user where username #{username} and password #{password}/select /mapperParameterTest.java Testpublic void testCheckLogin(){SqlSession sqlSession SqlSessionUtils.getSqlSession();UserMapper mapper sqlSession.getMapper(UserMapper.class);User user mapper.checkLogin(admin,123456);System.out.println(user); }运行控制台报错 org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: org.apache.ibatis.binding.BindingException: Parameter ‘username’ not found. Available parameters are [arg1, arg0, param1, param2] ### Cause: org.apache.ibatis.binding.BindingException: Parameter ‘username’ not found. Available parameters are [arg1, arg0, param1, param2] 可以看到sql语句没有输出PersistenceException是配置文件解析错误BindingException是绑定参数时出现的异常。 Parameter ‘username’ not found. 参数username没有找到。 Available parameters are [arg1, arg0, param1, param2] 可用的参数时arg1, arg0, param1, param2。可参照此方案进行修改。 正确的写法 方式一 UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapper PUBLIC -//mybatis.org//DTD Mapper 3.0//EN http://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idcheckLogin resultTypeUserselect * from t_user where username #{arg0} and password #{arg1}/select /mapper运行可以正常输出信息查询到用户信息。 方式二 UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idcheckLogin resultTypeUser!--select * from t_user where username #{arg0} and password #{arg1}--select * from t_user where username #{param1} and password #{param2}/select /mapper运行可以正常输出信息查询到用户信息。 UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idcheckLogin resultTypeUser!--select * from t_user where username #{arg0} and password #{arg1}--!--select * from t_user where username #{param1} and password #{param2}--!--select * from t_user where username ${arg0} and password ${arg0}--select * from t_user where username ${param1} and password ${param2}/select /mapper如果当前参数有两个时mybatis会自动把这两个参数放在一个map集合中的。放在map集合中会以两种方式来存储数据。 第一种方式以arg0,arg1为键以参数值为值 第二种方式以parma1,param2为键以参数值为值。 相当于从map集合中访问存储的数据。通过map中的键访问对应的值。 5.3、map集合类型的参数 若mapper解耦中的方法需要的参数为多个时此时可以手动创建map集合将这些数据放在map中 UserMapper接口 package com.fan.mybatis.mapper;import com.fan.mybatis.pojo.User;/*** 3、若mapper接口方法的参数为map集合类型的参数* 只需要通过#{}和${}访问map集合的键就可以获取相对应的值一定要注意${}的单引号问题*/ public interface UserMapper {/*** 添加用户信息* param user*/void insertUser(User user); }ParameterTest.java Test public void testCheckLoginByMap(){SqlSession sqlSession SqlSessionUtils.getSqlSession();UserMapper mapper sqlSession.getMapper(UserMapper.class);MapString,Object map new HashMap();map.put(username,admin);map.put(password,123456);User user mapper.checkLoginByMap(map);System.out.println(user); }UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapperselect idcheckLoginByMap resultTypeUserselect * from t_user where username #{username} and password #{password}/select /mapper运行测试类 5.4、实体类类型的参数 添加用户信息 UserMapper接口 package com.fan.mybatis.mapper;import com.fan.mybatis.pojo.User;/*** 4、若mapper接口方法的参数为实体类类型的参数* 只需要通过#{}和${}访问是实体类中的属性名就可以获取相对应的属性值一定要注意${}的单引号问题* 属性名只跟getXxx和setXXX的方法名有关系把set和get去掉剩余的字母首字母小写就是当前的属性名*/ public interface UserMapper {/*** 添加用户信息* param user*/void insertUser(User user); }ParameterTest.java Test public void testInsertUser(){SqlSession sqlSession SqlSessionUtils.getSqlSession();UserMapper mapper sqlSession.getMapper(UserMapper.class);User user new User(null,root,123456,33,女,123qq.com);mapper.insertUser(user); }运行测试 5.5、使用Param注解标识参数 可以通过Param注解标识mapper接口中的方法参数 此时会将这些参数放在map集合中以Param注解的value属性值为键以参数为值以param1,param2…为键以参数为值只需要通过$ ${}需要手动加单引号。 User checkLoginByParam(Param(username) String username, Param(password) String password); 加上Param(“username”)后mybatis仍然会将两个参数放进map中放进map中的键就是Param括号中的username和password UserMapper接口 package com.fan.mybatis.mapper;import com.fan.mybatis.pojo.User; import org.apache.ibatis.annotations.Param;/*** 5、可以在mapper接口方法的参数上设置Param注解* 此时MyBatis会将这些参数放在map中以两种方式进行存储* a 以Param注解的value属性值为键以参数为值* b 以param1,param2...为键以参数为值* 只需要通过#{}和${}访问map集合的键就可以获取相对应的值一定要注意${}的单引号问题。*/ public interface UserMapper {/*** 验证登录使用Param* param username* param password* return*/User checkLoginByParam(Param(username) String username, Param(password) String password); }UserMapper.xml ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.fan.mybatis.mapper.UserMapper!-- User checkLoginByParam(Param(username) String username, Param(password) String password); --select idcheckLoginByParam resultTypeUserselect * from t_user where username #{username} and password #{password}/select/mapperParameterTest.java Test public void testCheckLoginByParam(){SqlSession sqlSession SqlSessionUtils.getSqlSession();UserMapper mapper sqlSession.getMapper(UserMapper.class);User user mapper.checkLoginByParam(admin,123456);System.out.println(user); }运行
http://www.w-s-a.com/news/913793/

相关文章:

  • 北京 网站建设咨询顾问公司网络公司有几家
  • 设计类网站如何用ps做网站首页
  • 品牌网站建设的关键事项设计网有哪些
  • 网站没收录徐州建设工程审图中心网站
  • 网站建设记账做什么科目erp系统有哪些软件
  • 泰拳图片做网站用哪里有做空包网站的
  • 查外链网站重庆做网站微信的公司
  • 有没有外包活的网站如何做网站快捷键的元素
  • 公司网站赏析网站制作2019趋势
  • 企业进行网站建设的方式有( )推广引流违法吗
  • 按营销型网站要求重做网站 费用点金网站建设
  • 深圳做网站互联网服务
  • 网站sem托管wordpress安装无法连接数据库
  • 深圳网站建设开发公司哪家好微信小程序商家入口
  • 江门站排名优化建立什么网站赚钱
  • 科普文章在那个网站做招聘网站代做
  • 监控设备东莞网站建设游戏网站域名
  • 对商家而言网站建设的好处网址导航怎么彻底删除
  • app设计网站模板企业展厅策划设计公司有哪些
  • wordpress销售主题手机网站关键词优化
  • 怎么查一个网站是什么程序做的三亚城乡建设局网站
  • 深圳分销网站设计公司做网站一般需要多久
  • 企业网站设计代码丹东seo排名公司
  • 企业网站建设定制开发服务网站建设说课ppt
  • 大连市城乡建设局网站网站免费网站入口
  • 做暧网站网站备案ps
  • 知名网站建设公司电话长子网站建设
  • 网站建设的意义与目的建立什么船籍港
  • 广州注册公司营业执照网站建设代码优化
  • 百度网站官网马克互联网主题 wordpress