mysql 排序 过滤_【MYSQL】-3 排序与过滤

上周加入数据蛙二期培训,结束了孤独战斗的现状。断断续续自学了3个月(当然看了各种视频和各种书,一把辛酸泪。。。),现在选择报班,主要还是觉得一个靠谱的组织和团队,可以极大缓解我学习过程中不时闪现的焦虑和无助,最重要的是少走弯路。毕竟青春不再,年华易逝,浪费可耻哈哈哈哈~

本文结合个人情况,依据学习规划,对《mysql必知必会》前9章内容关于排序和过滤操作进行知识点整理。

一 . 排序

子句排序:

select [column1] from [table] order by [column2],[column3]…..

column1 与 column2 不要求相等,也可以多列排序。

select prod_name from products order by prod_name;

升降顺序:默认升序 asc;降序 desc

select prod_id,prod_price,prod_name from products

order by prod_price desc,prod_name;

与 limit 组合找到最值

select prod_price from products

order by prod_price desc

limit 1;

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

二 . 过滤

1. 按照指定条件搜索数据

where:select [column1],[column2] from [table] where [column3]=x

特性1:匹配时不区分大小写;

特性2: 用单引号限定字符串;

select prod_name,prod_price from products

where prod_name='fuses';

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

特性3:匹配范围可以用 between ...and...;in ——见特性7

特性4:where 和 order by 同时使用时,order by 放后面;

select prod_name,prod_price from products

where prod_price between 5 and 10

order by prod_price;

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

特性5:用于检查null值

select cust_id from customers

where cust_email is null;

特性6:结合逻辑操作符and & or,and 具有更高优先级

select vend_id,prod_name,prod_price

from products

where vend_id=1002 or vend_id=1003 and prod_price>=

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

这里搜索出来的是1003厂商制造的价格小于10美元的数据,和1002制造的数据。

特性7:匹配范围还可以用 in(小值,大值)

select prod_name,prod_price from products

where vend_id in(1002,1003)

order by prod_name;

同义转换:功能与 or 相当

select prod_name,prod_price from products

where vend_id =1002 or vend_id =1003

order by prod_name;

这里用in 和or 查询结果都一样:

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

in操作符的优势

1) 在使用长的合法选项清单时,IN操作符的语法更清楚且更直观。

2) 在使用IN时,计算的次序更容易管理(因为使用的操作符更少)。

3) IN操作符一般比OR操作符清单执行更快。

4) IN的最大优点是可以包含其他SELECT语句,使得能够更动态地建立WHERE子句

not 取反,找出与条件列不匹配的行

select prod_name,prod_price

from products

where vend_id not in (1002,1003)

order by prod_name;

2. like:运用通配符进行过滤

%:任何字符出现任意次数 (....where [column] like 'a%'):列 column 中以a开头的所有行;

select prod_id,prod_name

from products

where prod_name like 'jet%';

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

注意:% 可以匹配尾空格;不能匹配null值

_:匹配任意单个字符

select prod_id,prod_name

from products

where prod_name like '_ ton anvil';

通配符使用注意事项:

1)优先选择其他操作符;

2)使用时最好不要用在搜索模式的开始位置,会使得搜索变慢。

3)注意通配符放置的位置

3. 复杂过滤:正则表达式

regexp:...where [column] regexp 'abc'

完全匹配:

select prod_name from products

where prod_name regexp'%1000'

order by prod_name;

部分匹配:. :任意一个字符

select prod_name from products

where prod_name regexp '.000'

order by prod_name;

a6178b0e5653?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

注意,这里换成like,是不输出结果的。

select prod_name from products

where prod_name regexp'1000'

order by prod_name;

为什么呢?

regexp vs like:

1)like 匹配整个列,regex在列值内匹配。比如匹配1000,like会在一列中查找字符为1000的值,但是regexp在每一个值中找到含有字符1000的值;

2)like 必须和通配符结合使用,否则不返回结果。

或匹配(or):a|b—— 匹配 a 或者 b

匹配多项中的一项:[123]-匹配1或2或3

匹配特殊字符:前面加\

匹配范围:[1-9]

select prod_name

from products

where prod_name regexp '[1-8] ton'

order by prod_name;

其他匹配规则:

^ 文本的开始 ;$ 文本的结尾 ;[[:<:>:]] 词的结尾

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337919.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

构造函数 构造代码块_构造函数必须没有代码

构造函数 构造代码块构造函数中应完成多少工作&#xff1f; 在构造函数内部进行一些计算然后封装结果似乎是合理的。 这样&#xff0c;当对象方法需要结果时&#xff0c;我们将准备好它们。 听起来是个好方法&#xff1f; 不&#xff0c;这不对。 这是一个坏主意&#xff0c;原…

C语言按位逻辑运算符总结-与、或、非、异或

点击上方蓝字关注我&#xff0c;了解更多咨询C中有按位逻辑运算符&#xff1a;按位取反、按位与、按位或、按位异或。这4个运算符可以用于整型&#xff0c;包括char类型。按位操作针对每一个位进行操作&#xff0c;不影响左右两边的位。4个运算符的作用总结如下&#xff1a;一、…

java quartz没执行完_quartz 防止上一任务未执行完毕,下一时间点重复执行

/*** 订单监控类* 定时扫描所有待付款订单&#xff0c;超时自动取消* Created by huangbaidong* 2017/3/29.*/Componentpublic classOrderMonitorJob {ResourceprivateRedisUtil redisUtil;ResourceprivateBsdOrderService bsdOrderService;ResourceprivateBsdDFKOrderCacheMan…

th:each嵌套_难题:嵌套的computeIfAbsent

th:each嵌套总览 Java 8库在地图上有一个新方法&#xff0c;computeIfAbsent。 这是将地图转换为与键关联的对象的缓存的非常有用的方法。 但是&#xff0c;您可能没有考虑过一种组合。 如果您在内部调用computeIfAbsent会发生什么。 map.computeIfAbsent(Key.Hello, s ->…

java图论_玩转算法系列--图论精讲 面试升职必备(Java版)

第1章 和bobo老师一起&#xff0c;玩转图论算法欢迎大家来到我的新课程&#xff1a;《玩转图论算法》。在这个课程中&#xff0c;我们将一起完整学习图论领域的经典算法&#xff0c;培养大家的图论建模能力。通过这个课程的学习&#xff0c;你将能够真正地&#xff0c;玩转图论…

C语言的本质——位运算

点击上方蓝字关注我&#xff0c;了解更多咨询位运算是指按二进制进行的运算。在系统软件中&#xff0c;常常需要处理二进制位的问题。C语言提供了6个位操作运算符。这些运算符只能用于整型操作数&#xff0c;即只能用于带符号或无符号的char,short,int与long类型。C语言提供的位…

servlet异步_关于Servlet和异步Servlet

servlet异步Servlet API是Java EE标准的一部分&#xff0c;自1998年正式发布2.1规范以来&#xff0c;一直是基于Java的企业体系结构的重要组成部分。 它是一种自以为是的API&#xff0c;用于服务围绕一些基本概念构建的请求/响应协议&#xff1a; 兼容的容器 &#xff0c;这是…

Java创新型模式_java设计模式--创建型模式(一)

2016-04-24 10:10:34创建型模式&#xff1a;工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式注意&#xff1a;工厂模式可以分为三类&#xff1a; 1)简单工厂模式(Simple Factory) 2)工厂方法模式(Factory Method) 3)抽象工厂模式(Abstract Factory)这三种模式从上…

原来这就是C语言的基本结构—循环结构?!

点击上方蓝字关注我&#xff0c;了解更多咨询今天我们就着重说说循环结构。循环结构分为三种&#xff0c;分别是for、while、dowhile;我们首先说第一种&#xff1a;for循环..他的代码格式为&#xff1a;for(判断的数值初始化;判断条件;改变判断数值大小){循环语句块&#xff1b…

可视化编码_编码:可视化位图

可视化编码在过去的一个月左右的时间里&#xff0c;我每天花费一些时间来阅读Neo4j代码库的新部分&#xff0c;以使其更加熟悉&#xff0c;而我最喜欢的类之一是Bits类&#xff0c;该类可以完成所有底层工作&#xff0c;到磁盘。 特别是&#xff0c;我喜欢它的toString方法&am…

java count 在哪一类里_java 5线程中 Semaphore信号灯,CyclicBarrier类,CountDownLatch计数器以及Exchanger类使用...

先来讲解一下Semaphore信号灯的作用:可以维护当前访问自身的线程个数&#xff0c;并提供了同步机制&#xff0c;使用semaphore可以控制同时访问资源的线程个数例如&#xff0c;实现一个文件允许的并发访问数。请看下面的演示代码:1 public classSemaphoreTest2 {3 public stati…

spring aop示例_Spring查找方法示例

spring aop示例当一个bean依赖于另一个bean时&#xff0c;我们使用setter属性或通过构造函数注入bean。 getter方法将向我们返回已设置的引用&#xff0c;但是假设您每次调用getter方法时都想要一个依赖bean的新实例&#xff0c;那么您可能将不得不采用另一种方法。 在本文中…

java hive查询_java程序调用hive查询的一个异常

最近在java程序中调用hive做查询时&#xff0c;碰到一个异常&#xff0c;被困扰了许久&#xff0c;经过几番调试&#xff0c;逐步把问题定位清楚。在异常描述前先给出异常信息&#xff1a;java.sql.SQLException: Error while processing statement: FAILED: Execution Error, …

C/C++入门易错点及常用小技巧

点击上方蓝字关注我&#xff0c;了解更多咨询C语言诞生至今已有30多个年头了&#xff0c;主要集中在需要运行效率比较高的行业&#xff0c;比如现在的游戏开发以及高效服务器等等。C学习难度比其它语言都要高&#xff0c;这是不可否认的&#xff0c;其学习难度主要在于它的复杂…

quasar_Quasar和Akka –比较

quasaractor模型是用于容错和高度可扩展系统的设计模式。 角色是独立的工作程序模块&#xff0c;它们仅通过消息传递与其他角色进行通信&#xff0c;可以与其他角色隔离而失败&#xff0c;但是可以监视其他角色的故障并在发生这种情况时采取一些恢复措施。 角色是简单&#xff…

java 文件封装_Java 封装

在面向对象程式设计方法中&#xff0c;封装(英语&#xff1a;Encapsulation)是指&#xff0c;一种将抽象性函式接口的实作细节部份包装、隐藏起来的方法。封装可以被认为是一个保护屏障&#xff0c;防止该类的代码和数据被外部类定义的代码随机访问。要访问该类的代码和数据&am…

什么是自定义函数?精简回答

点击上方蓝字关注我&#xff0c;了解更多咨询1、自定义函数是程序员根据所要完成的功能&#xff0c;自己写出的源代码实现该功能。2、自定义函数和库函数一样&#xff0c;具有函数名&#xff0c;返回值类型&#xff0c;和函数参数。示例1&#xff1a;写一个函数找出两整数的值。…

为什么awt_为AWT的机器人创建DSL

为什么awtJava SDK附带了java.awt.Robot类&#xff0c;该类允许键盘和鼠标输入的自动化以及屏幕捕获的创建。 当您要编写一个模拟用户输入的小型测试应用程序时&#xff0c;或者只想自动化一些重复文本的输入时&#xff0c;此功能非常有用。 但是您不想每次都编写一个完整的Jav…

C++ 创建文件夹的几种方式汇总确定不来看看???

点击上方蓝字关注我&#xff0c;了解更多咨询1、使用 system() 调用 dos 命令。2、使用头文件 direct.h 中的 access 和 mkdir 函数。关于 direct.h 我觉得 维基百科 上介绍的不错3、调用 Windows API 函数。4、调用 MFC 封装好的接口函数。不推荐此方法&#xff0c;出错的话会…

java语言使用箭头键画线_Java:使用带箭头键的按键

按向下箭头键启动程序,首先观察字符串.这里看一下这个示例程序&#xff1a;import java.awt.*;import java.awt.event.*;import javax.swing.*;public class KeyBindingExample{private void createAndDisplayGUI(){JFrame frame new JFrame("Key Binding Example")…