一.检索前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基础知识的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

    SQL 基础知识梳理(六)-  函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...

  7. [SQL] SQL 基础知识梳理(七)- 集合运算

    SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...

  8. 常见SQL语句和SQL基础知识

    引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name   k ...

  9. SQL 基础知识终极指南

    什么是数据库? 数据库是以电子方式从系统中存储和检索的大量数据集合. 存储在数据库中的结构化数据被处理.操纵.控制和更新以执行各种操作. 行业中使用的一些流行数据库是 Oracle.MySQL.Pos ...

  10. sql基础知识集锦

    Sql常用语法 下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT ...

随机推荐

  1. 从零开始学android开发-布局中 layout_gravity、gravity、orientation、layout_weight

    线性布局中,有 4 个及其重要的参数,直接决定元素的布局和位置,这四个参数是 android:layout_gravity ( 是本元素相对于父元素的重力方向 ) android:gravity (是 ...

  2. GLSL实现Ambient Occlusion 【转】

    http://blog.csdn.net/a3070173/archive/2008/11/04/3221181.aspx 相信使用OpenGl或DirectX3D的朋友都知道到固定功能管线在光照处理 ...

  3. PhotoShop中画圆角矩形最简单方法(图文并茂)!

    PhotoShop中画圆角矩形最简单方法(图文并茂)! 1. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZHhubjUyMA==/font/5a6L5L ...

  4. Android播播放完SD卡指定文件夹音乐之后,自动播放下一首

    最近做一个项目,需要连续播放音乐,播放完一首歌之后,自动播放完下一首歌.不要重复播放. 代码如下: package com.example.asyncplayer_ex; import java.io ...

  5. android数据库操作之直接读取db文件

    在对数据库操作时,常用的有两种方法: 1.在代码中建库.建表: 2.直接将相关库.表建立好,将db文件拷贝至assets目录下:     现在来看看第二种方法:   private String Ge ...

  6. 进程间通信之popen和pclose函数

    常见的操作是创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose.这两个函数实现的操作是:创建一个管道,调用fork产生一个子进程, ...

  7. c语言中文件的操作

    所谓“文件”是指一组相关数据的有序集合.这个数据集有一个名称,叫做文件名.实际上在前面的各章中我们已经多次使用了文件,例如源程序文件.目标文件.可执行文件.库文件 (头文件)等. 文件通常是驻留在外部 ...

  8. BootStrap2学习日记12---注册表单

    <form method="" action="" class="form-horizontal"> <frameset& ...

  9. Github 的一些基本操作

    1.创建一个新的repository: 先在github上创建并写好相关名字,描述.例如这样一个地址: https://github.com/test/test2.git 回到本地目录如hellowo ...

  10. (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。

    floyd解法 今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂. 模版题,纯练打字... HDU 1874: #include <cstdio> #define MAXN ...