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

大气的网站源码西乡做网站哪家便宜

大气的网站源码,西乡做网站哪家便宜,门户网站的特点及优势,腾讯云轻量服务器别忘了请点个赞收藏关注支持一下博主喵#xff01;#xff01;#xff01;! ! ! 下篇更新#xff1a; 秒鲨后端之MyBatis【3】自定义映射resultMap、动态SQL、MyBatis的缓存、MyBatis的逆向工程、分页插件。 默认的类型别名 MyBatis的增删改查 添加 !--int insertUs…别忘了请点个赞收藏关注支持一下博主喵! ! ! 下篇更新 秒鲨后端之MyBatis【3】自定义映射resultMap、动态SQL、MyBatis的缓存、MyBatis的逆向工程、分页插件。 默认的类型别名 MyBatis的增删改查 添加 !--int insertUser();-- insert idinsertUserinsert into t_user values(null,admin,123456,23,男,12345qq.com) /insert删除 为什么delete函数的返回值为int从数据库操作的角度来看大多数数据库管理系统如MySQL、Oracle、SQL Server等在执行DELETE语句时会返回一个表示受影响的行数即被删除的行数的整数值。(同理增删改都是返回一个表示受影响的行数) !--int deleteUser();-- delete iddeleteUserdelete from t_user where id 6 /delete修改 !--int updateUser();-- update idupdateUserupdate t_user set username 张三 where id 5 /update查询一个实体类对象 !--User getUserById();-- select idgetUserById resultTypecom.atguigu.mybatis.bean.User select * from t_user where id 2 /select//如何打印结果 User user userMapper.getUserById(); System.out.println(user);查询集合多行多列 !--ListUser getUserList();-- select idgetUserList resultTypecom.atguigu.mybatis.bean.Userselect * from t_user /select//如何打印结果 Listuser list mapper.getAlluer(); list,foreach(user - System.out.println(user));注意 查询的标签select【只有select才要】必须设置属性resultType或resultMap用于设置实体类和数据库表的映射关系因为mybatis不知道要用哪个映射关系所以才会报错 resultType自动映射(类型)用于属性名和表中字段名一致的情况设置的是默认的映射关系resultMap设置自定义的映射关系用于一对多或多对一或字段名和属性名不一致的情况 当查询的数据为多条时不能使用实体类作为返回值只能使用集合否则会抛出异常TooManyResultsException但是若查询的数据只有一条可以使用实体类或集合作为返回值例如 User getUserById()、List getUserList() idea中如何设置文件的配置模板 1. mybatis-config.xml核心配置文件 这样就可以快速创建mybatis-config.xml核心配置文件了 然后再设置一下这个模板的代码不固定的地方则空白即可如类型别名所在的包最后的映射文件等等具体情况具体设置。 2. properties文件的模板 我们这里设置一个模板名jdbc.properties的模板:因为核心配置文件我设置了properties所以也得必须创建该properties所以就来弄一个模板 3. 映射文件的模板 下面是mapper接口文件即创建的是interface-java类根据不同用法创建不同的mapper接口文件故不设置模板。如下创建了名为UserMapper的接口文件意为操作User表的接口文件 接口文件创建后创建映射文件 所以设置映射文件模板全类名为自己设置 这样就方便还可以设置如一种sql方法就用一种接口映射的方式这样设置多个方式可选。 MyBatis获取参数值的两种方式重点 MyBatis获取参数值的两种方式${}和#{}${}的本质就是字符串拼接#{}的本质就是占位符赋值${}使用字符串拼接的方式拼接sql若为字符串类型或日期类型的字段进行赋值时需要手动加单引号但是#{}使用占位符赋值的方式拼接sql此时为字符串类型或日期类型的字段进行赋值时可以自动添加单引号 单个字面量类型的参数 若mapper接口中的方法参数为单个的字面量类型此时可以使用${}和#{}以任意的名称最好见名识意获取参数的值即如#{aaa}也行记住重要的只是#{}位置和传入的值对不对注意${}需要手动加单引号 !--User getUserByUsername(String username);-- select idgetUserByUsername resultTypeUserselect * from t_user where username #{username} /select!--User getUserByUsername(String username);-- select idgetUserByUsername resultTypeUser select * from t_user where username ${username} /select多个字面量类型的参数 3.5.9以上的mybatis依赖可以直接用变量(参数)名而不用arg0arg1和param1param2了 若mapper接口中的方法参数为多个时此时MyBatis会自动将这些参数以如下两种方式放在一个map集合中 以arg0,arg1…为键以参数为值以param1,param2…为键以参数为值 因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值注意${}需要手动加单引号。 使用arg或者param都行要注意的是arg是从arg0开始的param是从param1开始的 !--User checkLogin(String username,String password);-- select idcheckLogin resultTypeUser select * from t_user where username #{arg0} and password #{arg1} /select!--User checkLogin(String username,String password);-- select idcheckLogin resultTypeUserselect * from t_user where username ${param1} and password ${param2} /selectmap集合类型的参数 若mapper接口中的方法需要的参数为多个时此时可以手动创建map集合将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值注意${}需要手动加单引号 !--User checkLoginByMap(MapString,Object map);-- select idcheckLoginByMap resultTypeUserselect * from t_user where username #{username} and password #{password} /selectTest public void checkLoginByMap() {SqlSession sqlSession SqlSessionUtils.getSqlSession();ParameterMapper mapper sqlSession.getMapper(ParameterMapper.class);MapString,Object map new HashMap();map.put(usermane,admin);map.put(password,123456);User user mapper.checkLoginByMap(map);System.out.println(user); }实体类类型的参数 若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{}通过访问实体类对象中的属性名获取属性值注意${}需要手动加单引号。实际可能用到这个比较多 !--int insertUser(User user);-- insert idinsertUserinsert into t_user values(null,#{username},#{password},#{age},#{sex},#{email}) /insertTest public void insertUser() {SqlSession sqlSession SqlSessionUtils.getSqlSession();ParameterMapper mapper sqlSession.getMapper(ParameterMapper.class);User user new User(null,Tom,123456,12,男,123321.com);mapper.insertUser(user); }使用Param标识参数 可以通过Param注解标识mapper接口中的方法参数此时会将这些参数放在map集合中相当于第二和第三种方法的结合。 以Param注解的value属性值为键以参数为值以param1,param2…为键以参数为值 只需要通过${}和#{}访问map集合的键就可以获取相对应的值注意${}需要手动加单引号 !--User CheckLoginByParam(Param(username) String username, Param(password) String password);--select idCheckLoginByParam resultTypeUserselect * from t_user where username #{username} and password #{password}/selectTest public void checkLoginByParam() {SqlSession sqlSession SqlSessionUtils.getSqlSession();ParameterMapper mapper sqlSession.getMapper(ParameterMapper.class);mapper.CheckLoginByParam(admin,123456); }总结 建议分成两种情况进行处理 实体类类型的参数使用Param标识参数 MyBatis的各种查询功能 如果查询出的数据只有一条可以通过 实体类对象接收List集合接收Map集合接收结果{password123456, sex男, id1, age23, usernameadmin} 如果查询出的数据有多条一定不能用实体类对象接收会抛异常TooManyResultsException可以通过 实体类类型的LIst集合接收Map类型的LIst集合接收在mapper接口的方法上添加MapKey注解 查询一个实体类对象 /*** 根据用户id查询用户信息* param id* return*/ User getUserById(Param(id) int id);!--User getUserById(Param(id) int id);-- select idgetUserById resultTypeUserselect * from t_user where id #{id} /select查询一个List集合 /*** 查询所有用户信息* return*/ ListUser getUserList();!--ListUser getUserList();-- select idgetUserList resultTypeUserselect * from t_user /select查询单个数据 咱们这里的resultType依旧可以用User因为User数据库表里面有integer即通过User表识别查询的数据为integer当然也可以自己如下直接设置因为“单个数据”的“类型”这两个已知便自己写为integer /** * 查询用户的总记录数 * return * 在MyBatis中对于Java中常用的类型都设置了类型别名 * 例如java.lang.Integer--int|integer * 例如int--_int|_integer * 例如Map--map,List--list */ int getCount();!--int getCount();-- select idgetCount resultType_integerselect count(id) from t_user /select查询一条数据为map集合 之后会用的很多是因为有可能resultType设置为User我们自己写的数据库表有可能里面没有查询表结果中某一个或是多个的数据类型的映射即实体对象此时就可以直接用map集合把他们全部存入map。 /** * 根据用户id查询用户信息为map集合 * param id * return */ MapString, Object getUserByIdToMap(Param(id) int id);!--MapString, Object getUserByIdToMap(Param(id) int id);-- select idgetUserByIdToMap resultTypemapselect * from t_user where id #{id} /select !--结果{password123456, sex男, id1, age23, usernameadmin}--查询多条数据为map集合 方法一 /** * 查询所有用户信息为map集合 * return * 将表中的数据以map集合的方式查询一条数据对应一个map若有多条数据就会产生多个map集合此时可以将这些map放在一个list集合中获取 */ ListMapString, Object getAllUserToMap();!--MapString, Object getAllUserToMap();-- select idgetAllUserToMap resultTypemap select * from t_user /select !--结果[{password123456, sex男, id1, age23, usernameadmin},{password123456, sex男, id2, age23, username张三},{password123456, sex男, id3, age23, username张三}] --方法二 /*** 查询所有用户信息为map集合* return* 将表中的数据以map集合的方式查询一条数据对应一个map若有多条数据就会产生多个map集合并且最终要以一个map的方式返回数据此时需要通过MapKey注解设置map集合的键值是每条数据所对应的map集合*/ MapKey(id) MapString, Object getAllUserToMap();!--MapString, Object getAllUserToMap();-- select idgetAllUserToMap resultTypemapselect * from t_user /select !--结果{1{password123456, sex男, id1, age23, usernameadmin},2{password123456, sex男, id2, age23, username张三},3{password123456, sex男, id3, age23, username张三}} --特殊SQL的执行 模糊查询 /*** 根据用户名进行模糊查询* param username * return java.util.Listcom.atguigu.mybatis.pojo.User* date 2022/2/26 21:56*/ ListUser getUserByLike(Param(username) String username);!--ListUser getUserByLike(Param(username) String username);-- select idgetUserByLike resultTypeUser!--select * from t_user where username like %${mohu}%-- !--select * from t_user where username like concat(%,#{mohu},%)-- select * from t_user where username like %#{mohu}% /select其中select * from t_user where username like %#{mohu}%是最常用的 批量删除 只能使用${}如果使用#{}则解析后的sql语句为delete from t_user where id in (1,2,3)这样是将1,2,3看做是一个整体只有id为1,2,3的数据会被删除。正确的语句应该是delete from t_user where id in (1,2,3)或者delete from t_user where id in (1,2,3) /*** 根据id批量删除* param ids * return int* date 2022/2/26 22:06*/ int deleteMore(Param(ids) String ids);delete iddeleteMoredelete from t_user where id in (${ids}) /delete//测试类 Test public void deleteMore() {SqlSession sqlSession SqlSessionUtils.getSqlSession();SQLMapper mapper sqlSession.getMapper(SQLMapper.class);int result mapper.deleteMore(1,2,3,8);System.out.println(result); }动态设置表名 只能使用${}因为表名不能加单引号 /*** 查询指定表中的数据* param tableName * return java.util.Listcom.atguigu.mybatis.pojo.User* date 2022/2/27 14:41*/ ListUser getUserByTable(Param(tableName) String tableName);!--ListUser getUserByTable(Param(tableName) String tableName);-- select idgetUserByTable resultTypeUserselect * from ${tableName} /select添加功能获取自增的主键 使用场景: 当有班级表和学生表满足如下一对多或者多对多关系时需设置中间表时我们需要获取新添加的班级的id来给中间表。 t_clazz(clazz_id,clazz_name) t_student(student_id,student_name,clazz_id) 添加班级信息获取新添加的班级的id为班级分配学生即将某学的班级id修改为新添加的班级的id 在mapper.xml中设置两个属性 useGeneratedKeys设置当前标签中的sql使用了自增的主键 keyProperty因为增删改有统一的返回值是受影响的行数因此只能将获取的自增的主键放在传输的参数user对象的某个属性中(如下我们设置的为id属性即id列这样返回的每行数据就可以带上其对应的id了) /*** 添加用户信息* param user * date 2022/2/27 15:04*/ void insertUser(User user);!--void insertUser(User user);-- insert idinsertUser useGeneratedKeystrue keyPropertyidinsert into t_user values (null,#{username},#{password},#{age},#{sex},#{email}) /insert//测试类 Test public void insertUser() {SqlSession sqlSession SqlSessionUtils.getSqlSession();SQLMapper mapper sqlSession.getMapper(SQLMapper.class);User user new User(null, ton, 123, 23, 男, 123321.com);mapper.insertUser(user);System.out.println(user);//输出user{id10, usernameton, password123, age23, sex男, email123321.com}自增主键存放到了user的id属性中 }别忘了请点个赞收藏关注支持一下博主喵! ! ! 下篇更新 秒鲨后端之MyBatis【3】自定义映射resultMap、动态SQL、MyBatis的缓存、MyBatis的逆向工程、分页插件。
http://www.tj-hxxt.cn/news/132624.html

相关文章:

  • 用vs2010做的网站济南cms建站
  • WordPress缩略图边框阴影武夷山网站建设wzjseo
  • 电商网站的支付模块怎么做互联网开发软件
  • 常州做网站包括哪些自助网站免费注册
  • 网站建设投放广告网站 mysql数据库 字符
  • 大连网站开发公司shepiguo贵州企业网站开发公司
  • 郑州网站建设专注乐云seo万能素材库视频
  • 设计师接私单网站网站的术语
  • 淘宝上找人做网站wordpress网站更改主题信息
  • 企业为什么要网站建设个人怎么做网页
  • 自己做网站创业seo网站建设接单
  • 网站建设行业论坛上海市网站制作
  • 网站集约化建设宜昌网站seo
  • 邵阳学院研究生与学科建设处网站许昌中国建设银行官网站
  • 漯河做网站优化莱芜在线电话
  • 做企业云网站的企业网站设置二级域名
  • 农业局网站建设实施方案物联网方案设计与实现
  • 漳州网站建设网站制作大渡口区网站建设
  • 木门行业网站该怎么做公司简历模板图片
  • 山东港基建设集团网站wordpress页面大小调节
  • 重庆网站设计公司排行最好茶叶网站建设
  • 湖北建设网站首页重庆垫江网站建设
  • 长白山开发建设集团网站上饶专业的企业网站建设公司
  • php网站开发所需要的软件深圳网络推广哪家
  • 西安响应式网站建设交流建设网站
  • 网站设计怎么做一点首页就跳转哪个网站做h5号
  • 余姚什么网站做装修比较好邵阳公司网站建设
  • 网站设计与开发未来发展方向做食物网站应该考虑些什么
  • 当当网站建设与易趣网站对比wordpress企业免费主题下载地址
  • 影视公司网站设计银行营销活动方案