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

国外设计搜索网站青岛网站建设seo

国外设计搜索网站,青岛网站建设seo,北京室内设计公司排名,泰安网站营销推广一、条件构造器关系 条件构造器关系介绍#xff1a; 绿色框#xff1a;抽象类 abstract 蓝色框#xff1a;正常 class 类#xff0c;可 new 对象 黄色箭头#xff1a;父子类关系#xff0c;箭头指向为父类 wrapper介绍#xff1a; Wrapper #xff1a;条件构造抽象类…一、条件构造器关系 条件构造器关系介绍 绿色框抽象类 abstract 蓝色框正常 class 类可 new 对象 黄色箭头父子类关系箭头指向为父类 wrapper介绍 Wrapper 条件构造抽象类最顶端父类 AbstractWrapper 用于查询条件封装生成 sql 的 where 条件 QueryWrapper Entity 对象封装操作类不是用lambda语法 UpdateWrapper Update 条件封装用于Entity对象更新操作 AbstractLambdaWrapper Lambda 语法使用 Wrapper统一处理解析 lambda 获取 column。 LambdaQueryWrapper 看名称也能明白就是用于Lambda语法使用的查询Wrapper LambdaUpdateWrapper Lambda 更新封装Wrapper 二、项目实例 函数名说明举例eq等于 例eq ( name , 老叶 ) — name ’ 老叶 ’ne不等于 例ne ( name , 老叶 ) — name ’ 老叶 ’gt大于 例gt ( age , 18 ) — name 18ge大于等于 例ge ( age , 18 ) — name 18lt小于 例lt ( age , 18 ) — name 18le小于等于 例le ( age , 18 ) — name 18betweenBetween 值1 and 值2例between ( age , 18, 30 ) — age between 18 and 30notBetweenNOT Between 值1 and 值2例notBetween ( age , 18, 30 ) — age not between 18 and 30likeLIKE ’ %值% ’例like ( name , 王 ) — name like ’ %王% ’notLikeNOT LIKE ’ %值% ’例notLike ( name , 王 ) — name not like ’ %王% ’likeLeftLIKE ’ %值 ’例likeLeft ( name , 王 ) — name like ’ %王 ’likeRightLIKE ’ 值% ’例likeRight ( name , 王 ) — name like ’ 王% ’isNull字段 IS NULL例isNull ( name ) — name is nullisNotNull字段 IS NOT NULL例isNotNull ( name ) — name is not nullin字段 IN (v0, v1, …)例in ( age , {1, 2, …} ) — age in (1, 2, …)notIn字段 NOT IN (v0, v1, …)例notIn ( age , {1, 2, …} ) — age not in (1, 2, …)inSql字段 IN ( sql语句 )inSql ( id , select id from table where id 3 ) — id in ( select id from table where id 3 )notInSql字段 NOT IN ( sql语句 )notInSql ( id , select id from table where id 3 ) — id not in ( select id from table where id 3 )groupBy分组GROUP BY 字段, …例groupBy ( id , name ) — group by id, nameorderBy排序ORDER BY 字段, …例orderBy ( id , name ) — order by id ASC, name DESCorderByAsc排序ORDER BY 字段, … ASC例orderByAsc ( id , name ) — order by id ASC, name ASCorderByDesc排序ORDER BY 字段, … DESC例orderByDesc ( id , name ) — order by id DESC, name DESChavingHAVING ( sql语句 )例having ( sum ( age ) { 0 } , 11 ) —having sum ( age ) 11or拼接 OR注意事项主动调用 or 表示紧接着下一个方法不是用 and 连接(不调用 or 则默认为使用 and 连接)例eq ( id , 1 ).or ().eq ( name , 老王 ) — id 1 or name ’ 老王 ’and嵌套 AND例and ( i - i.eq ( name , 李白 ).ne ( status , 活着 ) ) — and ( name ’ 李白 ’ and status ’ 活着 ’ )nested正常嵌套不带 AND 或者 OR例nested ( i - i.eq ( name , 李白 ).ne ( status , 活着 ) ) — ( name ’ 李白 ’ and status ’ 活着 ’ )apply拼接 sql注意事项该方法可用于数据库函数 动态入参的 params 对应前面 sqlHaving 内部的 { index } 部分这样是不会有 sql 注入风险的反之会有例apply ( date_format ( dateColum, ’ %Y-%m-%d ’ ) { 0 } , 2023-10-30 ) — date_format ( dateColumn, ’ %Y-%m-%d ’ ) ’ 2023-10-30 ’last无视优化规则直接拼接到 sql 的最后注意事项只能调用一次多次调用以最后一次为准。有 sql 注入的风险请谨慎使用例last ( limit 1 )exists拼接 EXISTS ( sql语句 )例exists ( select id from table where age 1 ) — exists ( select id from table where age 1 )notExists拼接 NOT EXISTS ( sql语句 )例notExists ( select id from table where age 1 ) — not exists ( select id from table where age 1 ) 1、根据简单条件查询 /*** 通过单个ID主键进行查询*/Testpublic void selectById() {User user userMapper.selectById(1094592041087729666L);System.out.println(user);}/*** 通过多个ID主键查询*/Testpublic void selectByList() {ListLong longs Arrays.asList(1094592041087729666L, 1094590409767661570L);ListUser users userMapper.selectBatchIds(longs);users.forEach(System.out::println);}/*** 通过Map参数进行查询*/Testpublic void selectByMap() {MapString, Object params new HashMap();params.put(name, 郑梓妍);params.put(age, 18);ListUser users userMapper.selectByMap(params);users.forEach(System.out::println);}2、Wrapper 条件构造器 MyBatis Plus 还提供了 Wrapper 条件构造器具体使用请看如下代码 /*** 名字包含雨* 且年龄小于40* p* WHERE name LIKE %雨% AND age 40*/Testpublic void selectByWrapperOne() {QueryWrapperUser wrapper new QueryWrapper();wrapper.like(name, 雨).lt(age, 40);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 名字包含雨* 且年龄大于20小于40* 且邮箱不能为空* p* WHERE name LIKE %雨% AND age BETWEEN 20 AND 40 AND email IS NOT NULL*/Testpublic void selectByWrapperTwo() {QueryWrapperUser wrapper Wrappers.query();wrapper.like(name, 雨).between(age, 20, 40).isNotNull(email);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 名字为王姓* 或者年龄大于等于25* 按照年龄降序排序年龄相同按照id升序排序* p* WHERE name LIKE 王% OR age 25 ORDER BY age DESC , id ASC*/Testpublic void selectByWrapperThree() {QueryWrapperUser wrapper Wrappers.query();wrapper.likeRight(name, 王).or().ge(age, 25).orderByDesc(age).orderByAsc(id);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 查询创建时间为2019年2月14* 且上级领导姓王* p* WHERE date_format(create_time,%Y-%m-%d) 2019-02-14 AND manager_id IN (select id from user where name like 王%)*/Testpublic void selectByWrapperFour() {QueryWrapperUser wrapper Wrappers.query();wrapper.apply(date_format(create_time,%Y-%m-%d) {0}, 2019-02-14).inSql(manager_id, select id from user where name like 王%);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 查询王姓* 且年龄小于40或者邮箱不为空* p* WHERE name LIKE 王% AND ( age 40 OR email IS NOT NULL )*/Testpublic void selectByWrapperFive() {QueryWrapperUser wrapper Wrappers.query();wrapper.likeRight(name, 王).and(qw - qw.lt(age, 40).or().isNotNull(email));ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 查询王姓* 且年龄大于20 、年龄小于40、邮箱不能为空* p* WHERE name LIKE ? OR ( age BETWEEN ? AND ? AND email IS NOT NULL )*/Testpublic void selectByWrapperSix() {QueryWrapperUser wrapper Wrappers.query();wrapper.likeRight(name, 王).or(qw - qw.between(age, 20, 40).isNotNull(email));ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** (年龄小于40或者邮箱不为空) 并且名字姓王* WHERE ( age 40 OR email IS NOT NULL ) AND name LIKE 王%*/Testpublic void selectByWrapperSeven() {QueryWrapperUser wrapper Wrappers.query();wrapper.nested(qw - qw.lt(age, 40).or().isNotNull(email)).likeRight(name, 王);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 查询年龄为30、31、32* WHERE age IN (?,?,?)*/Testpublic void selectByWrapperEight() {QueryWrapperUser wrapper Wrappers.query();wrapper.in(age, Arrays.asList(30, 31, 32));ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}/*** 年龄为30、31、32* 查询一条数据* limit 1*/Testpublic void selectByWrapperNine() {QueryWrapperUser wrapper Wrappers.query();wrapper.in(age, Arrays.asList(30, 31, 32)).last(limit 1);ListUser users userMapper.selectList(wrapper);users.forEach(System.out::println);}三、具体使用操作 注意以下条件构造器的方法入参中的 column 均表示数据库字段 1、ge、gt、le、lt、isNull、isNotNull Test public void testDelete() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.isNull(name).ge(age, 12).isNotNull(email);int result userMapper.delete(queryWrapper);System.out.println(delete return count result); }update user set deleted 1 where deleted 0 and name is null and age ? and email is not null2、eq、ne selectOne 返回的是一条实体记录当出现多条时会报错 Test public void testSelectOne() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.eq(name, Tom);User user userMapper.selectOne(queryWrapper);System.out.println(user); }3、between、notBetween 包含大小边界 Test public void testSelectCount() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.between(age, 20, 30);Integer count userMapper.selectCount(queryWrapper);System.out.println(count); }select count(1) from user where deleted 0 and age Between 20 and 304、allEq 包含大小边界 Test public void testSelectList() {QueryWrapperUser queryWrapper new QueryWrapper();MapString, Object map new HashMap();map.put(id, 2);map.put(name, Jack);map.put(age, 20);queryWrapper.allEq(map);ListUser users userMapper.selectList(queryWrapper);users.forEach(System.out::println); }select id, name, age, email, create_time, update_time, deleted, version from user where deleted 0 and name Jack and id 2 and age 205、like、notLike、likeLeft、likeRight selectMaps 返回 Map 集合列表 Test public void testSelectMaps() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.notLike(name, e).likeRight(email, t);ListMapString, Object maps userMapper.selectMaps(queryWrapper);//返回值是Map列表maps.forEach(System.out::println); }select id, name, age, email, create_time, update_time, deleted, version from user where deleted 0 and name not like %e% and email like t%6、in、notIn、inSql、notInSql、exists、notExists in、notIn notIn(age, {1,2,3}) --- age not in (1,2,3)notIn(age, 1, 2, 3) --- age not in (1,2,3)inSql、notInSql可以实现子查询 inSql(age, 1,2,3) --- age in (1,2,3)inSql(id, select id from table where id 3) --- id in (select id from table where id 3)Test public void testSelectObjs() {QueryWrapperUser queryWrapper new QueryWrapper();//queryWrapper.in(id, 1, 2, 3);queryWrapper.inSql(id, select id from user where id 3);ListObject objects userMapper.selectObjs(queryWrapper);//返回值是Object列表objects.forEach(System.out::println); }select id, name, age, email, create_time, update_time, deleted, version from user where deleted 0 and id in (select id from user where id 3)7、or、and 这里使用的是 UpdateWrapper 不调用 or 则默认为使用 and 连接 Test public void testUpdate() {//修改值User user new User();user.setAge(99);user.setName(Andy);//修改条件UpdateWrapperUser userUpdateWrapper new UpdateWrapper();userUpdateWrapper.like(name, h).or().between(age, 20, 30);int result userMapper.update(user, userUpdateWrapper);System.out.println(result); }update user set name Andy, age 99, update_time ? where deleted 0 and ((name like %h%) or (age between 20 and 30))-- 名称包含’h‘或名年龄在20到30岁之间8、嵌套or、嵌套and 这里使用 lambda 表达式or 中的表达式最后翻译成 sql 时会被加上圆括号 Test public void testUpdate2() {//修改值User user new User();user.setAge(99);user.setName(Andy);//修改条件UpdateWrapperUser userUpdateWrapper new UpdateWrapper();userUpdateWrapper.like(name, h).or(i - i.eq(name, 李白).ne(age, 20));int result userMapper.update(user, userUpdateWrapper);System.out.println(result); }update user set name Andy, age 99, update_time ? where deleted 0 and name like %h% or (name %李白% and age 20)-- 名称包含’h‘或名称包含‘李白’且年龄不等于20岁9、orderBy、orderByDesc、orderByAsc Test public void testSelectListOrderBy() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.orderByDesc(id);ListUser users userMapper.selectList(queryWrapper);users.forEach(System.out::println); }select id, name, age, email, create_time, update_time, deleted, version from user where deleted 0 order by id desc10、last 直接拼接到 sql 的最后 注意只能调用一次多次调用以最后一次为准有 sql 注入的风险请谨慎使用 Test public void testSelectListLast() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.last(limit 1);ListUser users userMapper.selectList(queryWrapper);users.forEach(System.out::println); }select id, name, age, email, create_time, update_time, deleted, version from user where deleted 0 limit 111、指定要查询的列 Test public void testSelectListColumn() {QueryWrapperUser queryWrapper new QueryWrapper();queryWrapper.select(id, name, age);ListUser users userMapper.selectList(queryWrapper);users.forEach(System.out::println); }select id, name, age from user where deleted 012、set、setSql 最终的 sql 会合并 user.setAge()以及 userUpdateWrapper.set() 和 setSql() 中的字段 Test public void testUpdateSet() {//修改值User user new User();user.setAge(99);//修改条件UpdateWrapperUser userUpdateWrapper new UpdateWrapper();userUpdateWrapper.like(name, h).set(name, 老李头) //除了可以查询还可以使用set设置修改的字段.setSql( email 123qq.com); //可以有子查询int result userMapper.update(user, userUpdateWrapper); }update user set age 99, update_time ?, name 老李头, email 123qq.com where deleted 0 and name like %h%四、项目中的实际应用 实例1-- 包含 eq 相等的比较方法 实例2-- 包含 ge le 等比较方法及分页查询 好事定律每件事最后都会是好事如果不是好事说明还没到最后。
http://www.zqtcl.cn/news/188775/

相关文章:

  • 企业网站建设推广实训报告网站目录
  • 找做课件的网站网站建设柒首先金手指9
  • 秦皇岛网站建设公司wordpress百度编辑器
  • 潍坊网站建设联系方式农业网站开发
  • 河北网站制作网站设计依赖于什么设计
  • 深圳网站优化培训wordpress内页关键词
  • 上栗网站建设企业网站建设报价方案
  • 广州网站开发公司公司级别网站开发
  • 做网站备案哪些条件怎样选择网站的关键词
  • 有没有专门做名片的网站忘记网站后台账号
  • 重庆建设工程招标网站印尼建设银行网站
  • 什么是网站流量优化四川住房建设厅网站
  • 现在还有企业做网站吗做百度推广送的网站
  • 公司年前做网站好处互联网推广运营是做什么的
  • 公司网站建设杭州钓鱼网站制作的报告
  • 宁海有做网站的吗网络规划设计师需要掌握哪些
  • 百度云注册域名可以做网站明码有了主机如何做网站
  • 门户网站推广方案连云港市电信网站建设
  • 网站程序如何制作app商城开发价格
  • 用易语言做攻击网站软件国药控股北京有限公司
  • 宁津 做网站湛江招聘网最新招聘
  • 网站建设优化服务器asp企业网站
  • 门窗网站源码建筑模板厂家联系方式
  • 太原网站建设解决方案做建筑机械网站那个网站好
  • 丹徒做网站产品外贸营销推广方案
  • 信息技术 网站建设教案做是么网站
  • 网站建设培训报名wordpress 到小程序
  • 郑州做网站软件建设网站培训
  • 做网站卖东西赚钱吗凡科互动官网登陆
  • 免费写作网站通道一通道二通道三免费