1. SQL语言概述

1.1 SQL语言特点

  • 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理。
  • 统一性,操作任务主要包括:查询数据;插入、修改和删除数据;建立、修改和删除数据对象;控制对数据和数据对象的读写;保证数据库一致性和完整性。
  • 易于移植性。

1.2 SQL语言的分类

  • 数据查询语言(DQL),主要是SELECT语句、
  • 数据操纵语言(DML),主要包括INSERT、UPDATE、DELETE。
  • 事务控制语言(TCL),主要包括COMMIT、ROLLBACK、SAVEPOINT。
  • 数据定义语言(DDL),用于建立、修改和删除数据库对象,主要包括CREATE、ALTER、DROP。
  • 数据控制语言(DCL),用于执行权限授予和权限收回操作,主要包括GRANT、REVOKE。

2. 检索数据

select {[distinct|all]columns|*}

[into table_name]

from {tables|views|other select}

[where conditions]

[group by columns]

[having conditions]

[order by columns]

筛选查询:

  • 比较筛选,主要有6种情况:=,!=,>=,<=,<,>
  • 特殊关键字筛选,LIKE/IN/BETWEEN/IS NULL等关键字,它们都可以与NOT合用。如:NOT...BETWEEN...AND
  • 逻辑筛选,AND、OR、NOT(正常情况,可以用“AND”和“比较运算符”来代替“BETWEEN...AND”关键字)。

分组查询:

排序查询:

多表关联查询:

  • 内连接(INNER JOIN),当只合用JOIN关键字时,默认内连接操作。
  • 外连接(LEFT JOIN/RIGHT JOIN/FULL JOIN),左外连接查询表示查询结果还包含左表中不满足连接条件的数据行,以此类推。
  • 自连接,如:select emp2.ename 上层管理者,em1.ename as 下属员工 from emp em1 left join emp em2 on em1.mgr=em2.empno order by em1.mgr;
  • 交叉连接(CROSS JOIN),交叉连接实际上就是不需要任何连接条件的连接,执行结果是一个笛卡尔积,这种查询结果是冗余的,但可以通过WHERE子句来过滤出有用的信息。

3. Orcale常用系统函数

参考:Oracle学习笔记之五(实践:常用函数)

4. 子查询

4.1 单行子查询

单行子查询是指返回一行数据的子查询语句。当在WHERE子句中引用单行子查询时,可以使用单行比较运行符(=、>、<、>=、<=、<>)。

select empno,ename,sal from emp where sal>(select avg(sal) from emp);

4.2 多行子查询

多行子查询是指返回多行数据的子查询语句。当在WHERE子句使用多行子查询时,必须使用多行运算符(IN、ANY、ALL)。

select empno,ename,job from emp where deptno IN (select deptno from dept where dname<>’SALES’);

ANY运算符必须与单行比较运算符结合使用,并且返回行只要匹配子查询的任何一个结果即可。

select deptno,ename,sal from emp where sal > ANY (select sal from emp where deptno=10) and deptno<>10;

ALL运算符必须与单行比较运算结合使用,并且返回行必须匹配所有子查询结果。

select deptno,ename,sal from emp where sal > ALL (select sal from emp where deptno=30);

4.3 并联子查询

内查询的执行需要借助于外查询,而外查询的执行又离不开内查询的执行。

比如:列出员工工资大于此员工所在岗位的平均工资的清单

select empno,ename,sal from emp f where sal>(select avg(sal) from emp where job=f.job) order by job;

5. 操作数据库

5.1 插入数据(INSERT语句)

INSERT INTO table_name [(column_name1[,column_name2]…)]

VALUES(express1[,express2]…)

INSERT INTO table_name [(column_name1[,column_name2]...) selectSubquery

5.2 更新数据(UPDATE语句)

UPDATE table_name

SET   {column_name1=express1[,column_name2=express2...]

| (column_name1[,column_name2…])=(selectSubquery)}

[WHERE condition]

在将UPDATE语句与SELECT语句组合使用时,必须保证SELECT语句返回单一的值。

5.3 删除数据(DELETE语句、TRUNCATE语句)

DELETE FROM table_name

[WHERE condition]

TRUNCATETABLE table_name

Oracle学习笔记之四,SQL语言入门的更多相关文章

  1. Oracle学习笔记之四sp1,Oracle 11g的常用函数

    从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i)    分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...

  2. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  3. 学习笔记:oracle学习三:SQL语言基础之sql语言简介、用户模式

    目录 1.sql语言简介 1.1 sql语言特点 1.2 sql语言分类 1.3 sql语言的编写规则 2.用户模式 2.1 模式与模式对象 2.2 实例模式scott 本系列是作为学习笔记,用于记录 ...

  4. 学习笔记:oracle学习三:SQL语言基础之检索数据:简单查询、筛选查询

    目录 1. 检索数据 1.1 简单查询 1.1.1 检索所有列 1.1.2 检索指定的列 1.1.3 查询日期列 1.1.4 带有表达式的select语句 1.1.5 为列指定别名 1.1.6 显示不 ...

  5. Oracle学习笔记四 SQL命令(二):SQL操作语言类别

    SQL分为下列语言类别 1.数据定义语言(DDL) Create.Alter.Drop 2.数据操纵语言(DML) Insert.Select.Delete.Update 3.事务控制语言(TCL) ...

  6. 吴裕雄--天生自然ORACLE数据库学习笔记:SQL语言基础

    select empno,ename,sal from scott.emp; SELECT empno,ename,sal FROM scott.emp; selECT empno,ename,sal ...

  7. Oracle学习笔记六 SQL常用函数

    函数的分类 Oracle 提供一系列用于执行特定操作的函数 SQL 函数带有一个或多个参数并返回一个值 以下是SQL函数的分类:

  8. Oracle学习笔记五 SQL命令(三):Group by、排序、连接查询、子查询、分页

    GROUP BY和HAVING子句 GROUP BY子句 用于将信息划分为更小的组每一组行返回针对该组的单个结果 --统计每个部门的人数: Select count(*) from emp group ...

  9. Oracle RAC学习笔记:基本概念及入门

    Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章]    oracle 10g real applica ...

随机推荐

  1. [Functional Programming 101] runWIth, evalWith, execWith

    Recentlly, I am learning crocks.js ADT libaray. In the beginning, it is hard to understand when to u ...

  2. linux下如何查看所有的用户和组信息?

    /etc/group  文件是用户组的配置文件. /etc/passwd 文件是用户的配置文件. 使用cat.more.less.head.tail以及vim等命令都可以查看.修改这两个配置文件. 说 ...

  3. Hive Python Streaming的原理及写法

    在Hive中,须要实现Hive中的函数无法实现的功能时,就能够用Streaming来实现. 其原理能够理解成:用HQL语句之外的语言,如Python.Shell来实现这些功能,同一时候配合HQL语句, ...

  4. 火狐浏览器Firefox Firefox中的xpi文件是什么

    firefox中的xpi文件是什么? 问一下 最佳答案 XPI是什么? firefox中的xpi实际上类似于IE中的插件或扩展(如Flash插件等). 格式一般为.Zip, 由XUL.Javascri ...

  5. jQuery和CSS3超酷表单美化插件

     这是一款效果很精美炫酷的jQuery和CSS3联系方式表单美化插件.大多数站点上都有让用户填写的联系方式表单,一个设计良好的表单可以大大的提升用户的体验度.该表单美化插件在原生HTML表单的基础上进 ...

  6. Java从零开始学三十三(JAVA IO- File类)

    一.简述 在整个io包中,唯一表示与文件本身有关的类就是File类.使用File类可以进行创建或删除文件等常用操作.要想使用File类,则首先要观察File类的构造方法,此类的常用构造方法如下所示: ...

  7. JavaScript三(语法、关键保留字及变量)

    基本概念 一.区分大小写 在ECMAScript中的一切(变量.函数名.操作符)都是区分大小写的. 如变量名test和Test分别表示两个不同的变量, 二.标识符 所谓标识符,就是指变量.函数.属性的 ...

  8. iOS开发 - 获取真机沙盒数据

    今天要获取之前真机測试时写入沙盒的数据, 本来以为挺麻烦的. 后来捣腾了一下, 才知道原来这么简单... 以下直接看详细步骤. 前提: 真机已经通过USB和你的电脑连接上了! 1.进入Organize ...

  9. 如何解决Cydia提示错误

    删除/etc/apt/sources.list.d该目录下的cydia.list进入var/lib/apt/lists删掉此文件夹下的所有文件,以及partial下的文件,但须保留这个空文件夹.进入/ ...

  10. git检查与放弃本地的代码修改情况

    git diff  可以查看当前没有add 的内容修改(不在缓冲区的文件变化) git diff --cached查看已经add但没有commit 的改动(在缓冲区的文件变化) git diff HE ...