zoukankan      html  css  js  c++  java
  • MySQL中的查询子句

    查询语句

    字句名称 使用目的
    select 确定结果集中应该包含那些列
    from 指明所要提取数据的表,以及这些表是如何连接的
    where 过滤不需要的数据
    group by 用于对具有想用列值的行进行分组
    having 过滤掉不需要的组
    order by 按一个或多个列,对最后结果集中的行进行排序

    select语句由几个组建或者说子句构成。不过在MySQL中,只有一种子句是必不可少的,那就是select子句。

    select子句

    SELECT * FROM department;
    

    在此查询中,from子句只列出了一个表(department),并且select子句只是在结果集中需要包含所有department表中的列(通过 * 号表示)。该查询的含义可以表是如下:

    • 显示department表中所有的行和列

    当然也可以选择只获取department表终各列的一个子集,例如:

    SELECT name FROM department;
    

    因此select子句的作用可以概括如下:

    • select子句用于在所有可能的列中,选择查询结果集要包含哪些列。

    我们可以在select子句中加上:

    • 字符,比如数字或字符串;
    • 表达式,比如transaction.amount*-1;
    • 调用内建函数,比如 ROUND(transaction.amount,2);
    • 用户自定义的函数调用。

    例:

    SELECT emp_id,
    	'ACTIVE',
    	emp_id * 3.14159,
    	UPPER(lname)
    FROM employee;
    

    如果只是需要执行一个内建函数或对简单的表达式求值可以完全省略from子句,例如:

    SELECT VERSION(), USER(), DATABASE();
    

    将会返回MySQL版本,用户,和当前的数据库名。

    列的别名

    可以在select子句中的每个元素后面增加列别名来达到自定义标签的目的:

    SELECT emp_id,
    	'ACTIVE' status,
    	emp_id * 3.14159 empid_x_pi,
    	UPPER(lname) last_name_upper
    FROM employee;
    

    为了在子句中更清晰地表是列名,可以在这些别名前面加上关键字as,例如:

    SELECT emp_id,
    	'ACTIVE' AS status,
    	emp_id * 3.14159 AS empid_x_pi,
    	UPPER(lname) AS last_name_upper
    FROM employee;
    

    去除重复的行

    可以在select关键字之后加上distinct关键字来去除重复的行:

    SELECT DISTINCT cust_id FROM account;
    

    from子句

    • from子句定义了查询中所使用的表,以及连接这些表的方式。

    是关联行的集合。包含3种类型:

    • 永久表(使用create table语句创建的表)
    • 临时表(子查询所返回的表);
    • 虚拟表(使用create view子句创建的视图)。

    子查询产生的表

    子查询是包含在另一个查询中的查询。
    子查询可以出现在select语句中的各个部分并且被包含在圆括号中。
    在from子句中,子查询的作用是根据其他查询子句(其中的from子句可以与其他表进行交互)产生临时表。例:

    SELECT 
    	e.emp_id, e.fname, e.lname
    FROM (
    	SELECT 
    		emp_id, fname, lname, start_date, title
    	FROM employee
    ) e;
    

    在外围查询中,通过别名(本例中为e)来引用子查询。

    视图

    视图是存储在数据字典中的查询,它的行为表现得像一个表,但实际上并不拥有任何数据(实际上是一张虚拟表)。
    当发出一个对视图的查询时,该查询会被绑定到视图定义上,以产生最终被执行的查询。
    例:定义一个查询employee表的视图,其中包含了一个对内奸函数的调用:

    CREATE VIEW employee_vw AS 
    SELECT emp_id, fname, lname, 
        YEAR(start_date) start_year
    FROM employee;
    

    当视图被创建后,并没有产生或存储任何数据,服务器只是简单地保留该查询以供将来使用。现在既然该视图已经存在了,就可以对其发出查询请求,例如:

    SELECt emp_id, start_year FROM employee_vw;
    

    表连接

    如果from子句中出现了多个表,那么要求同时包含各表之间的连接条件。例:

    SELECT employee.emp_id, employee.fname,
    	employee.lname, department.name dept_name
    FROM employee 
    INNER JOIN
    	department
    ON employee.dept_id = department.dept_id
    

    定义表别名

    有两种在from子句之外引用表的方式:

    • 使用完整的表名称,如 employee.emp_id;
    • 为每一个表指定别名,并在查询中需要的地方使用该别名。

    例:

    SELECT e.emp_id, e.fname,
    	e.lname, d.name dept_name
    FROM employee e
    INNER JOIN
    	department d
    ON e.dept_id = d.dept_id
    

    还可以在别名前面使用as关键字,如:

    SELECT e.emp_id, e.fname,
    	e.lname, d.name dept_name
    FROM employee AS e
    INNER JOIN
    	department AS d
    ON e.dept_id = d.dept_id
    

    where子句

    where子句用于在结果集中过滤掉不需要的行。
    例如,如果需要查询employee表,但是只想获取头衔为head teller的雇员数据,那么就可以在查询的where子句中进行指定:

    SELECT emp_id, fname, lname, start_date, title
    FROM employee
    WHERE title = 'Head Teller';
    

    该子句中只包含了一个过滤条件,但在需要时可以同时包含更多的条件,它们之间使用操作符and、or或者not分割:

    SELECT emp_id, fname, lname, start_date, title
    FROM employee
    WHERE title = 'Head Teller'
    AND start_date > '2018-01-01'
    

    如果在where子句中需要同时使用and和or等操作符,可以使用圆括号来进行条件分组:

    SELECT emp_id, fname, lname, start_date, title
    FROM employee
    WHERE (title = 'Head Teller' AND start_date > '2018-01-01')
    OR (fname='zifeiy' AND start_date > '2017-01-01')
    

    group by和having子句

    group by子句用于根据列值对数据进行分组。
    在使用group by子句的同时可能还需要使用having子句,它能够以与where子句类似的方式对分组数据进行过滤。

    下面的查询首先为每个部门计算其所含的雇员数,然后返回至少包含2个雇员的部门名称:

    SELECT d.name, count(e.emp_id) num_employees
    FROM department d INNER JOIN employee e
    ON d.dept_id = e.dept_id
    GROUP BY d.name 
    HAVING count(e.emp_id) > 2;
    

    order by子句

    order by子句用于对结果及中的原始列数据或是根据列数据计算的表达式结果进行排序。
    例:

    SELECT open_emp_id, product_cd
    FROM account
    ORDER BY open_emp_id;
    

    业科技结合多列进行排序:

    SELECT open_emp_id, product_cd
    FROM account
    ORDER BY open_emp_id, product_cd;
    

    现在结果及中首先根据雇员ID排序,然后根据账户类型排序。

    在order by子句中各列出现的顺序决定了对各列进行排序的次序。

    1.升序或降序排序

    在排序时,可以通过关键字asc和desc指定是升序还是降序。
    由于默认情况下是升序排序,因此只需要在想要降序排序时加上desc关键字即可。例:

    SELECT account_id, product_cd, open_date, avail_balance
    FROM account
    ORDER BY avail_balance DESC;
    

    2.根据表达式排序

    可以在order by子句后增加表达式来进行排序:

    SELECT cust_id, cust_type_cd, city, state, fed_id 
    FROM customer 
    ORDER BY RIGHT(fed_id, 3);
    

    3.根据数字占位符排序

    如果需要根据select子句中的列来排序,那么可以选择使用该列位于select子句中的位置号来替代列名。
    例如,加沙需要根据返回的第2列和第5列排序,则可以采用如下方法:

    SELECT emp_id, title, start_date, fname, lname
    FROM employee
    ORDER BY 2, 5;
    
  • 相关阅读:
    display:none;与visibility:hidden;的区别
    前端优化:雅虎35条
    JQ中find()和filter()的区别
    attr属性
    媒体查询器(转)@media screen and
    javascript解决URL (转)
    使用 js 处理 html entities(转)
    FileReader详解与实例---读取并显示图像文件
    HTML5中File对象初探
    createTextRange和createRange的一些用法(重点)
  • 原文地址:https://www.cnblogs.com/zifeiy/p/8804529.html
Copyright © 2011-2022 走看看