SQL基础知识

 

一.检索前5行数据

  1.SQL Server和Access中使用SELECT时,可以使用TOP关键字来限制最多返回多少行

  SELECT TOP 5 prod_name FROM Products;

 

  2.DB2

  SELECT prod_name FROM Products FETCH 5 ROWS ONLY;

 

  3.MySQL、MariaDB、PostgreSQL、SQLite中需要使用LIMIT子句

  SELECT prod_name FROM Products LIMIT 5 OFFSET 5;(OFFSET指定从哪开始,LIMIT指定行数)

 

二.空值检查

  *NULL无值(no value)它于字段包含0、空字符串或仅仅包含空格不同.

  *确定是否为NULL,不能用=比较,用is NULL 或 is not NULL

 

三.AND和OR操作符

  *SQL在处理OR操作符前,优先处理AND操作,操作符有可能会被错误组合,所以最好加上圆括号

  *... WHERE P_NAME='Y' OR P_NAME='L' AND P_PRICE<100  ( P_NAME='L'且P_PRICE<100和P_NAME='Y'的所有结果) 

  *... WHERE (P_NAME='Y' OR P_NAME='L') AND P_PRICE<100  ( P_NAME='L'或P_NAME='Y'且P_PRICE<100的所有结果) 

 

四.聚集函数

  *AVG()、MAX()、MIN()、SUM()默认忽略null值得列

  *COUNT(column)会忽略为null值得列,COUNT(*)不会忽略null

 

五.子查询

  放在WHERE子句中

  *SELECT cust_id FROM order where order_num IN (SELECT order_num FROM orderItems WHERE prod_id='RGAN01');

  放在SELECT子句中

  *SELECT cust_name,(SELECT COUNT(*) FROM orders WHERE orders.cust_id=customers.cust_id) as orders FROM customers

 

六.联结查询

  内联结(等值联结)

  *SELECT vend_name,prod_name FROM vendors ,products WHERE vendors.vend_id=products.vend_id;

  *SELECT vend_name,prod_name FROM vendors INNER JOIN products ON vendors.vend_id=products.vend_id;

  自联结(自己跟自己进行等值联结)

  自然联结(自动匹配同名的列,虽然很方便,不用指定匹配的列)NATURAL JOIN

  外联结 LEFT OUTER JOIN(匹配左边所有的行)RIGHT OUTER JOIN (匹配右边所有的行) FULL OUTER JOIN(匹配所有关联的行以及两个表的不关联的行)

 

七.组合查询

  UNION 两个查询的并集(默认去掉重复行)

  UNION ALL 两个查询的并集(保留重复行)

  MINUS 两个查询的差集

  INTERSECT 两个查询的交集

  注意:每个查询必须包含相同的列、表达式或聚集函数;列的数据类型必须兼容。

 

八.数据插入

  插入完整的行

  *INSERT INTO customers VALUES('123','pro','1111');

  插入行的一部分

  *INSERT INTO customers(cust_id,cust_name) VALUES('123','pro');

  插入检索出的数据

  *INSERT INTO customers (cust_id,cust_name,cust_phone) SELECT cust_id,cust_name,cust_phone FROM custNew;

  创建表并插入检索出的数据

  *CREATE TABLE customers AS SELECT * FROM custNew;

 

九.更新和删除数据

  更新某行

  UPDATE customers SET cust_name='ljm' , cust_phone=123 WHERE cust_id=123;

  删除某列

  UPDATE customers SET cust_name=null WHERE cust_id=123;

  删除某行

  DELETE FROM customers WHERE cust_id=123;

  注意:除非确定对所有的行进行操作,否则都要加上WHERE子句

 

posted @ 2017-01-03 10:02  Nreo  阅读(151)  评论(0编辑  收藏  举报