zoukankan      html  css  js  c++  java
  • SQL基础(一):SQL语法和命令

    一、语法:

    1、SQL 对大小写不敏感:SELECT 与 select 是相同的。

    2、某些数据库系统要求在每条 SQL 语句的末端使用分号。分号是在数据库系统中分隔每条 SQL 语句的标准方法,这样就可以在对服务器的相同请求中执行一条以上的 SQL 语句。

    二、一些最重要的 SQL 命令:

    • SELECT - 从数据库中提取数据
    • UPDATE - 更新数据库中的数据
    • DELETE - 从数据库中删除数据
    • INSERT INTO - 向数据库中插入新数据
    • CREATE DATABASE - 创建新数据库
    • ALTER DATABASE - 修改数据库
    • CREATE TABLE - 创建新表
    • ALTER TABLE - 变更(改变)数据库表
    • DROP TABLE - 删除表
    • CREATE INDEX - 创建索引(搜索键)
    • DROP INDEX - 删除索引

      下面是选自 "Websites" 表的数据:

      

    1、SQL SELECT 语句

      SELECT 语句用于从数据库中选取数据。结果被存储在一个结果表中,称为结果集

      语法:SELECT column_name,column_name FROM table_name;  与  SELECT * FROM table_name;

    SELECT name,country FROM Websites;
    //从 "Websites" 表中选取 "name" 和 "country" 列

    2、SQL SELECT DISTINCT 语句

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

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

      语法:SELECT DISTINCT column_name,column_name FROM table_name;

    SELECT DISTINCT country FROM Websites;
    //从 "Websites" 表的 "country" 列中选取唯一不同的值,也就是去掉 "country" 列重复值

    3、SQL WHERE 子句

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

      语法:SELECT column_name,column_name FROM table_name WHERE column_name operator value;

    SELECT * FROM Websites WHERE country='CN';
    //从 "Websites" 表中选取国家为 "CN" 的所有网站

      注意:文本字段和数值字段:SQL 使用单引号来环绕文本值(大部分数据库系统也接受双引号)。在上个实例中 'CN' 文本字段使用了单引号。用单引号引起来,表示是字符串,字符串要区分大小写。如果是数值字段,请不要使用引号。

    SELECT * FROM Websites WHERE id=1;

      下面的运算符可以在 WHERE 子句中使用:

      =:等于      <>:不等于(有些版本中可被写成 !=)

      >,<,>=,<=:大于,小于,大于等于,小于等于

      BETWEEN:在某范围内

      LIKE:搜索某种模式

      IN:指定针对某个列的多个可能值

     4、SQL AND & OR 运算符

      用于基于一个以上的条件对记录进行过滤:如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录;如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。

    SELECT * FROM Websites
    WHERE country='CN'
    AND alexa > 50;
    //从 "Websites" 表中选取国家为 "CN" 且alexa排名大于 "50" 的所有网站
    SELECT * FROM Websites
    WHERE country='USA'
    OR country='CN';
    //从 "Websites" 表中选取国家为 "USA" 或者 "CN" 的所有客户
    SELECT * FROM Websites
    WHERE alexa > 15
    AND (country='CN' OR country='USA');
    //也可以把 AND 和 OR 结合起来(使用圆括号来组成复杂的表达式),从 "Websites" 表中选取 alexa 排名大于 "15" 且国家为 "CN" 或 "USA" 的所有网站

    5、SQL ORDER BY 关键字

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

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

       语法:SELECT column_name,column_name FROM table_name ORDER BY column_name,column_name ASC|DESC;

    SELECT * FROM Websites
    ORDER BY alexa;
    //从 "Websites" 表中选取所有网站,并按照 "alexa" 列排序,默认升序
    SELECT * FROM Websites
    ORDER BY alexa DESC;
    //降序排列
    SELECT * FROM Websites
    ORDER BY country,alexa;
    //多列:按照 "country" 和 "alexa" 列排序

    6、SQL INSERT INTO 语句

      INSERT INTO 语句用于向表中插入新记录。

      语法:

      (1)第一种形式无需指定要插入数据的列名,只需提供被插入的值即可:INSERT INTO table_name VALUES (value1,value2,value3,...);

      (2)第二种形式需要指定列名及被插入的值:INSERT INTO table_name (column1,column2,column3,...) VALUES (value1,value2,value3,...);

    INSERT INTO Websites (name, url, alexa, country)
    VALUES ('百度','https://www.baidu.com/','4','CN');
    //插入一个新行

    7、SQL UPDATE 语句

      UPDATE 语句用于更新表中已存在的记录。

      语法:UPDATE table_name SET column1=value1,column2=value2,... WHERE some_column=some_value;

      注意:WHERE 子句规定哪条记录或者哪些记录需要更新。如果您省略了 WHERE 子句,所有的记录都将被更新!

    UPDATE Websites 
    SET alexa='5000', country='USA' 
    WHERE name='菜鸟教程';
    //把 "菜鸟教程" 的 alexa 排名更新为 5000,country 改为 USA

      Update 警告!在更新记录时要格外小心!在上面的实例中,如果我们省略了 WHERE 子句,如下所示:

    UPDATE Websites SET alexa='5000', country='USA'

      执行以上代码会将 Websites 表中所有数据的 alexa 改为 5000,country 改为 USA。执行没有 WHERE 子句的 UPDATE 要慎重,再慎重。

     8、SQL DELETE 语句

      DELETE 语句用于删除表中的行。

      语法:DELETE FROM table_name WHERE some_column=some_value;

      注意:WHERE 子句规定哪条记录或者哪些记录需要删除。如果您省略了 WHERE 子句,所有的记录都将被删除!

    DELETE FROM Websites
    WHERE name='百度' AND country='CN';
    //从 "Websites" 表中删除网站名为 "百度" 且国家为 CN 的网站

      删除所有数据:可以在不删除表的情况下,删除表中所有的行。这意味着表结构、属性、索引将保持不变:

    DELETE FROM table_name;
    或
    DELETE * FROM table_name;
  • 相关阅读:
    51nod 1050 循环数组最大子段和
    51nod 1183 编辑距离
    百度之星初赛一 补题
    jquery click嵌套 事件重复注册 多次执行的问题
    Shell变量赋值语句不能有空格
    Linux得到某个文件夹内文件的个数
    Ubuntu14.04下sogou输入法的输入框只显示英文不显示中文的问题
    Eclipse中mybatis的xml文件没有提示,出现the file cannot be validated as the XML definition.....
    整理一下postgresql的扩展功能postgis和pgrouting的使用
    Windows应用程序未响应
  • 原文地址:https://www.cnblogs.com/goloving/p/7354077.html
Copyright © 2011-2022 走看看