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子句