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

七夕表白网站制作wordpress微信公众号推送

七夕表白网站制作,wordpress微信公众号推送,友情链接交换平台,长安响应式网站建设数据库相关链接: 数据库--数据类型:http://t.csdn.cn/RtqMD 数据库--三大范式、多表查询、函数sql:http://t.csdn.cn/udJSG 数据库--MySQL增删改查:http://t.csdn.cn/xkiti 一、一条sql语句通常包括: select fro…

数据库相关链接:

数据库--数据类型http://t.csdn.cn/RtqMD

数据库--三大范式、多表查询、函数sql:http://t.csdn.cn/udJSG

数据库--MySQL增删改查:http://t.csdn.cn/xkiti



一、一条sql语句通常包括:

select   from   join   where   group by   having   order by   聚合函数   limit   top  not  and    or   

二、浅谈执行顺序:

1)、首先确定一点,并不是按照我们写的语句顺序,从左—>右执行的

2)、获取结果集 ----> 指定查询的某些字段 --> 按照某些内容进行排序

首先 执行from ,join 确定表之间的关系,得到初步的----->结果集1

where 对结果集1 进行筛选 得到–>结果集2

group by 进行分组 -->结果集3

对结果集3进行having筛选,得到 ---->结果集 4

指定查询的字段:

select 指定需要查询的字段,也可以是聚合函数 —>结果去重

合并分组结果集,并按照order by 的 条件进行排序

如果存在limit 或者top之类的话,这是在最后才会执行的

 三、实际问题and or

mybatisplus遇到的and和or优先级的问题处理

需求:

想在name={ 张三,李四,王五 }  中查找  密码=88888 或者 年龄=20的记录

SELECT id,user_name,password,name,age,email,birthday FROM tb_user
WHERE password = 88888 OR age >= 20 AND name IN ("张三","李四","王五")

 java查询代码:

(使用MyBatisPlus查询)

@Testpublic void testLogicSelect(){QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.eq("password","88888").or().ge("age",20).in("name","张三","李四","王五");/*** SELECT id,user_name,password,name,age,email,birthday FROM tb_user* WHERE password = ? OR age >= ? AND name IN (?,?,?)*/List<User> userList = userMapper.selectList(wrapper);userList.forEach(System.out::println);}
查询结果: 

看似需求的sql查询代码没问题,执行出来就发现问题,为什么会有“赵六”

User(id=1, userName=zhangsan, password=88888, name=张三, age=18, email=test1@yh.cn, birthday=2019-09-26T11:42:01)
User(id=2, userName=lisi, password=88888, name=李四, age=20, email=test2@yh.cn, birthday=2019-10-01T11:42:08)
User(id=3, userName=wangwu, password=88888, name=王五, age=28, email=test3@yh.cn, birthday=2019-10-02T11:42:14)
User(id=4, userName=zhaoliu, password=88888, name=赵六, age=21, email=test4@yh.cn, birthday=2019-10-05T11:42:18)

问题的根本原因就是在于这个 AND 和 OR 的优先级。关系型运算符优先级高到低为:NOT > AND > OR

wrapper.eq("password","88888").or().ge("age",20).in("name","张三","李四","王五");

1.  先执行了后两句.ge("age",20)
                .in("name","张三","李四","王五");

2.  将1.执行结果和第一句进行or或运算

                .eq("password","88888")
                .or()
                .ge("age",20)
                .in("name","张三","李四","王五");

解决方案:

这里用到了lambda表达式,从格式化后的代码也可以看出运算级别。

代码里的wp名字随便起,但是不能是wrapper,即不能是wrapper = new QueryWrapper<>();

@Testpublic void testLogicSelect() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.and(wp -> wp   //这里的wp名字随便起,但是不能是wrapper,即不能是wrapper = new QueryWrapper<>();.eq("password", "88888").or().ge("age", 20)).in("name", "张三", "李四", "王五");/*** SELECT id,user_name,password,name,age,email,birthday FROM tb_user* WHERE password = ? OR age >= ? AND name IN (?,?,?)*/List<User> userList = userMapper.selectList(wrapper);userList.forEach(System.out::println);}

小结:

第一句话:从执行顺序中我们可以发现,所有的查询语句都是从 FROM 开始执行的。

第二句话:在实际执行过程中,每个步骤都会为下一个步骤生成一个虚拟表,这个虚拟表将作为下一个执行步骤的输入。 

第三句话:关系型运算符优先级高到低为:NOT > AND > OR

看到这了,点个赞再走吧!

http://www.yayakq.cn/news/441993/

相关文章:

  • 工程行业网站怎么建设大型商务网站
  • 做影视网站违法不做网站用商标吗
  • 发布信息的网站wordpress更改主题目录
  • 北京网站关键词排名公司做网站主机
  • 大型多媒体网站建设工具如何把网站做好
  • 网站活动怎么做的热门的网页设计工具有哪些
  • 星月网络公司做的网站开公司需要什么条件
  • 荆州做网站哪家好设计师网站使用不了
  • vs2008 手机网站开发如何制作个人主页
  • 定西临洮网站建设怎么做模板网站的报价表
  • windows 2012做网站伪静态易企秀电脑版
  • 怎么制作网站步骤做物流网站
  • 奥迪汽车建设网站苏州seo公司
  • 自适应单页网站模板wordpress文章会员
  • 具有品牌的网站建设个体营业执照网上年报
  • 重庆云阳网站建设电商商城开发
  • 昆明住房和城乡建设部网站自己开发的app软件怎么申请专利
  • 网站模板购买自助网站建设系统软件
  • 餐饮招商加盟网站建设贵阳网站制作服务商
  • 合肥专业网站优化费用国际站wap端流量
  • 安徽省建设工程招投标信息网免费网站优化怎么做
  • 购物网站的商品展示模块河南郑州建设网站制作
  • 长沙百度搜索排名优化北京seo排名公司
  • 理财公司网站模板下载站长交易网
  • 微信网站域名上海专业微信网站开发公司
  • 网站空间速度快wordpress定时器
  • 网站开发的项目开发计划企业推广方式推荐隐迅推
  • 广州建设网站首页东莞网站的建设
  • 网站无法访问电脑手机网站首页
  • 长宁网站建设公司网络设计师证怎么考