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子句
SQL基础知识的更多相关文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式
SQL 基础知识梳理(六)- 函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...
- [SQL] SQL 基础知识梳理(七)- 集合运算
SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...
- 常见SQL语句和SQL基础知识
引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name k ...
- SQL 基础知识终极指南
什么是数据库? 数据库是以电子方式从系统中存储和检索的大量数据集合. 存储在数据库中的结构化数据被处理.操纵.控制和更新以执行各种操作. 行业中使用的一些流行数据库是 Oracle.MySQL.Pos ...
- sql基础知识集锦
Sql常用语法 下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT ...
随机推荐
- C#文件读写常用类介绍
首先要熟悉.NET中处理文件和文件夹的操作.File类和Directory类是其中最主要的两个类.了解它们将对后面功能的实现提供很大的便利. 本节先对和文件系统相关的两个.NET类进行简要介 ...
- lightOJ 1030(期望)
题意:有一个迷宫是1×n的格子,一个人每到一个格子就能够把这个格子内的金子所有拿走,刚開始站在第1个格子,然后開始掷骰子得到点数x,他就要从当前位置走到加x的位置.假设发现位置是大于n的就又一次掷骰子 ...
- WIN8重见开始菜单
从win7进入win8感觉不适应,做为一个程序开发人员,更觉得不爽,因此想着如何恢复开始菜单,查了很多文章终于找到方法 首先,在桌面版Windows 8启动资源管理器,单击工具栏上的“查看”选项卡后, ...
- 也谈OpenFlow, SDN, NFV
Copyright (2014) 郭龙仓. All Rights Reserved. OpenFlow 传统的网络环境中,仅仅有路由器/交换机之间的接口/协议是标准化的,可是在网络设备内部,数据平面和 ...
- USACO prefix TrieTree + DP
/* ID:kevin_s1 PROG:prefix LANG:C++ */ #include <iostream> #include <cstdio> #include &l ...
- 在mac下安装jdk1.7(转)
转自:http://vela.diandian.com/post/2012-01-06/15379924 最近呢,想玩玩jdk1.7,不过mac平台下的jvm一直都是Apple自己改的,所有有些麻烦. ...
- SSAS 实例重命名
在某些时候我们可能想对现有的SSAS实例进行重命名之类的,比如:我以前有两个SSAS,一个2005,一个2008R2,其中我们2005是一开始安装的,并且是默认实例,2008R2是命名 ...
- Honda HDS IMMO PCM Code calculator Free Download
HDS IMMO PCM Code calculator software for Honda vehicle models is free download available in Eobd2.f ...
- Windows主机通过SSH连接虚拟机里的Linux系统
Windows 7 + VMware 11 VMWare里:编辑-虚拟网络编辑器-VMnet8(NAT模式)-NAT设置...添加主机端口和虚拟机IP地址以及虚拟机端口 Windows7系统:wind ...
- SQL Server:替换文本中的回车和换行符
--替换回车符 update master_locationSET street_number = REPLACE(street_number, CHAR(13), '') --替换换行符 updat ...