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" 表的数据:

  SQL基础(一):SQL语法和命令

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" 列重复值

SQL基础(一):SQL语法和命令

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=;

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

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

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

  BETWEEN:在某范围内

  LIKE:搜索某种模式

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

4、SQL AND & OR 运算符

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

SELECT * FROM Websites
WHERE country='CN'
AND alexa > ;
//从 "Websites" 表中选取国家为 "CN" 且alexa排名大于 "50" 的所有网站
SELECT * FROM Websites
WHERE country='USA'
OR country='CN';
//从 "Websites" 表中选取国家为 "USA" 或者 "CN" 的所有客户
SELECT * FROM Websites
WHERE alexa >
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/','','CN');
//插入一个新行

7、SQL UPDATE 语句

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

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

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

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

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

UPDATE Websites SET alexa='', 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;
上一篇:第七十节,css选择器


下一篇:logging日志文件配置