Mysql数据库实现多字段过滤的方法
我国移动互联网进入了飞速发展阶段,互联网人才日益受到企业的重视,其中php开发人才便是其中之一,在互联网旅游、金融、餐饮、娱乐、社交等一些新兴企业与软件开发企业中,php开发岗位相对占有核心地位,今天给大家分享的技术知识是—— mysql数据库如何实现多字段过滤。
1.多字段过滤查询
类比现实:查询公司中户籍是北京的、年龄超过30岁、性别是男的同事信息;
查询场景:查询商品名称是'king doll'、商品价格是9.49的商品。
查询sql:
select prod_id, prod_name, prod_price f rom products w here prod_name = 'king doll' and prod_price = 9.49;
查询结果:
2.多字段过滤连接
where字句中有多个字段进行查询过滤,过滤条件如何连接的呢?mysql允许给出多个where字句进行过滤,它们可以使用and或者or进行连接!
and连接类比现实:飞鹰小学5年2班身高超过1米3、不戴眼镜的男同学去操场上跑步。根据上述描述可以得出结论必须同时满足身高超过1米3、不戴眼镜、男生这三个条件的同学才需要去操场跑步,任何一个条件不满足都不用去操场跑步。
or连接类比现实:飞鹰小学5年2班身高超过1米3或不戴眼镜的同学去操场上跑步,根据上述描述可以得出结论只要满足身高超过1米3,或不戴眼镜这两个条件中任意一个条件的学生就要去操场跑步,即身高超过1米3的同学要去跑步,不戴眼镜的同学要去跑步。只要满足任意一个条件就需要去操场可以!
2.1and操作符
and运算符作用?用来指示检索满足所有给定条件的行。如果需要同时满足多个过滤条件,只需要在过滤条件之间添加and即可。
测试案例:查询商品单价在2-5之间,商品数量大于等于10的订单数据。
测试sql:
select * from orderitems w here item_price b etween 2 and 5 and quantity >= 10 order by order_num desc;
测试结果:
结果说明:如果有多个过滤条件需要同时满足,那么只需要在哪些过滤条件之间加上and关键字即可,查询条件理论上个数不限!
2.2or操作符
or操作符作用?用来指示检索满足任一给定条件的行。如果有多个过滤条件,那么需要过滤条件之间添加or即可。
测试案例:查询商品单价在3-5之间,或商品数量大于等于200的订单数据。
测试sql:
select * f rom orderitems w here item_price b etween 3 and 5 or quantity >= 200 order by order_num desc;
测试结果:
结果说明:只要满足商品单价在[3,5]之间,或者商品数量大于等于200的订单都满足条件。
2.3and和or进行对比
and必须满足全部条件,or只需要满足任一条件。
类比理解:现在有一群黑色和白色的公企鹅,如果取走黑色母企鹅,即select * from 企鹅 where 颜色=黑色 and 性别=母是查询不到企鹅的,因为两个条件必须同时满足,性别=母是没有;如果要取走颜色是白色或性别是母的企鹅,即select * from
企鹅 where 颜色=白色 or 性别=母,那么就可以将白色公企鹅查询出来。
2.4执行次序
将and和or结合使用进行复杂的数据过滤,那么就会出现执行次序的问题。
类比现实:比如小学中学习有括号四则混合运算,那么运算就要满足一定顺序;比如公司中查询月薪超过10w,并且职位是管理层或开发者的员工。
测试情景:查询商品单价是3.49,商品编号是bnbg01或bnbg03的订单。
分析思考:查询商品单价必须满足3.49,而商品编号只需要满足bnbg01或bnbg03任一个即可。
测试sql:
select * f rom orderitems w here item_price b etween 3 and 5 or quantity >= 200 order by order_num desc;
测试结果:
结果分析:
数据没有满足我们的预期,为什么呢?单价必须等于3.49。
在sql的世界中and运算符优先于or运算符,好比乘法运算优先于加减法运算先执行。
select * f rom orderitems w here item_price=3.49 and prod_id='bnbg01' or prod_id='bnbg03';
实际查询的结果是单价等于3.49并且商品编号是'bnbg01'的订单,或者商品编号是'bnbg03'的订单,所以和我们预期是不一样的!
如何解决and和or的顺序问题呢?使用圆括号明确地分组进行相应的操作。
测试sql:
select * f rom orderitems w here item_price= 3.49 and (prod_id = 'bnbg01' or prod_id= 'bnbg03') ;
测试结果:
结果分析:
从查询结果中可以看到,(prod_id='bnbg01' or prod_id='bnbg03')
作为1个整体变成1个执行单元;
圆括号的优先级高于and,and优先级高于or;
如果查询过滤条件过多,使用and或者or,那么就应该使用圆括号明确地分组操作,不要以来默认地计算次序!使用圆括号的好处在于可消除歧义,增强可读性。
总结
以上所述是小编给大家介绍的mysql数据库实现多字段过滤的方法,希望对大家有所帮助
下一篇: python多线程方式执行多个bat代码