zoukankan      html  css  js  c++  java
  • Sql

    SQL SELECT DISTINCT 语句

    在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。

    DISTINCT 关键词用于返回唯一不同的值。

    SELECT DISTINCT country FROM Websites;

    原表

    +----+--------------+---------------------------+-------+---------+
    | id | name         | url                       | alexa | country |
    +----+--------------+---------------------------+-------+---------+
    | 1  | Google       | https://www.google.cm/    | 1     | USA     |
    | 2  | 淘宝          | https://www.taobao.com/   | 13    | CN      |
    | 3  | 菜鸟教程      | http://www.runoob.com/    | 4689  | CN      |
    | 4  | 微博          | http://weibo.com/         | 20    | CN      |
    | 5  | Facebook     | https://www.facebook.com/ | 3     | USA     |
    +----+--------------+---------------------------+-------+---------+
    结果

    SQL WHERE 子句

    WHERE 子句用于提取那些满足指定标准的记录

     

      AND & OR

    SQL 语句从 "Websites" 表中选取国家为 "CN" 且alexa排名大于 "50" 的所有网站:SELECT * FROM Websites WHERE country='CN' AND alexa > 50;

      结合 AND & OR

    下面的 SQL 语句从 "Websites" 表中选取 alexa 排名大于 "15" 且国家为 "CN" 或 "USA" 的所有网站:SELECT * FROM Websites WHERE alexa > 15 AND (country='CN' OR country='USA');

    SQL ORDER BY 关键字

    ORDER BY 关键字用于对结果集按照一个列或者多个列进行排序。

    ORDER BY 关键字默认按照升序对记录进行排序。如果需要按照降序对记录进行排序,您可以使用 DESC 关键字。

      ORDER BY 多列

    下面的 SQL 语句从 "Websites" 表中选取所有网站,并按照 "country" 和 "alexa" 列排序:SELECT * FROM Websites ORDER BY country,alexa;

    SQL SELECT TOP, LIMIT 子句

    SELECT column_name(s)
    FROM table_name
    LIMIT number

    SQL IN 操作符

     IN 操作符允许您在 WHERE 子句中规定多个值

    SELECT * FROM Websites
    WHERE name IN ('Google','菜鸟教程');

    SQL BETWEEN 操作符

    BETWEEN 操作符用于选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期

    下面的 SQL 语句选取 name 以介于 'A' 和 'H' 之间字母开始的所有网站:SELECT * FROM Websites WHERE name BETWEEN 'A' AND 'H';

    下面的 SQL 语句选取 date 介于 '2016-05-10' 和 '2016-05-14' 之间的所有访问记录:SELECT * FROM access_log WHERE date BETWEEN '2016-05-10' AND '2016-05-14';

    SQL 别名

    通过使用 SQL,可以为表名称或列名称指定别名。

    在下面的情况下,使用别名很有用:

    • 在查询中涉及超过一个表
    • 在查询中使用了函数
    • 列名称很长或者可读性差
    • 需要把两个列或者多个列结合在一起

    下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。提示:如果列名称包含空格,要求使用双引号或方括号:

    SELECT name AS n, country AS c
    FROM Websites;
    在下面的 SQL 语句中,我们把三个列(url、alexa 和 country)结合在一起,并创建一个名为 "site_info" 的别名:
    注意需要使用CONCAT
    SELECT name, CONCAT(url, ', ', alexa, ', ', country) AS site_info
    FROM Websites;
    下面的 SQL 语句选取 "菜鸟教程" 的所访问记录。我们使用 "Websites" 和 "access_log" 表,并分别为它们指定表别名 "w" 和 "a"(通过使用别名让 SQL 更简短):
     
  • 相关阅读:
    修改浏览器的UserAgent来伪装你的浏览器和操作系统
    探索并发编程(七)分布式环境中并发问题
    通信网络规划的最短路径(最小生成树的2种算法介绍)
    iOS 面向模型的 SQL存储
    一个有趣的天平秤球问题
    飞机加油问题的粗略探究
    粗谈设计模式
    JDK动态代理[2]JDK动态代理的底层实现之Proxy源码分析
    Java集合系列[2]LinkedList源码分析
    JDK动态代理[4]ProxyGenerator生成代理类的字节码文件解析
  • 原文地址:https://www.cnblogs.com/xuchengfei/p/10523313.html
Copyright © 2011-2022 走看看