oracle数据库培训-sql基础篇

上传人:xh****66 文档编号:61934906 上传时间:2018-12-15 格式:PPT 页数:203 大小:1.82MB
返回 下载 相关 举报
oracle数据库培训-sql基础篇_第1页
第1页 / 共203页
oracle数据库培训-sql基础篇_第2页
第2页 / 共203页
oracle数据库培训-sql基础篇_第3页
第3页 / 共203页
oracle数据库培训-sql基础篇_第4页
第4页 / 共203页
oracle数据库培训-sql基础篇_第5页
第5页 / 共203页
点击查看更多>>
资源描述

《oracle数据库培训-sql基础篇》由会员分享,可在线阅读,更多相关《oracle数据库培训-sql基础篇(203页珍藏版)》请在金锄头文库上搜索。

1、SQL 语言基础,主要内容,基本的SELECT语句 约束和排序数据 单行函数 多表显示数据、组函数合计数据 创建和管理表 子查询&操纵数据 内置约束 创建视图 其他数据库对象,基本的select语句,目标,完成本课后, 您应当能够: 列出SQL SELECT语句的功能 执行基本的SELECT语句,SQL SELECT语句的功能,列选择:你能够使用SELECT语句的列选择功能选择表中的列,这些列是你想要用查询返回的。当你查询时,你能够选择你查询的表中指定的列。 行选择:你能够使用SELECT语句的行选择功能选择表中的行,这些行是你想要用查询返回的。你能够使用不同的标准限制你看见的行。 连接:你能

2、够使用SELECT语句的连接功能来集合数据,这些数据被存储在不同的表中,在它们之间可以创建连接。在后面的课程中你将学到更多关于连接的内容。,基本SELECT语句,SELECT *| DISTINCT column|expressionalias,. FROM table; SELECT 确定哪些列 FROM 确定哪张表,选择所有列与指定列,SELECT * FROM departments; 用跟在SELECT关键字后面的星号 (*),你能够显示表中数据的所有列。 SELECT department_id, location_id FROM departments; 你能够用SELECT语句来

3、显示表的指定列,指定列名之间用逗号分隔。,写SQL 语句,SQL 语句对大小写不敏感 SQL 语句可以写成一行或多行 关键字不能简写或分开折行 子句通常放在不同的行 缩进用于增强可读性,算术表达式,用算术运算符创建数字和日期数据的表达式 操作 说明 + 加 - 减 * 乘 / 除,使用算术运算符,SELECT last_name, salary, salary + 300 FROM employees; 优先级: 乘法和除法比加法和减法的优先级高 相同优先级的运算符从左到右计算 圆括号用于强制优先计算,并且使语句更 清晰 SELECT last_name, salary, 12*salary+

4、100 FROM employees;,空值,null 是一个未分配的、未知的,或不适用的值 null不是0,也不是空格 包含空值的算术表达式计算结果为空 SELECT last_name, job_id, salary, commission_pct FROM employees;,定义列别名,列别名: 改变列标题的名字 可用于计算结果 紧跟在列名后面在列名和别名之间可以有选项AS 关键字 如果别名中包含有空格、或者特殊字符、或者大小写敏感,要求用双引号 SELECT last_name AS name, commission_pct comm FROM employees;,连字运算符,连

5、字运算符: 连接列或者字符串到其它的列 用两个竖线表示(|) 构造一个字符表达式的合成列 SELECT first_name|last_name AS Employees FROM employees;,文字字符串,文字字符串是包含在SELECT列表中的一个字符串,一个数字或者一个日期 日期和字符的文字字符串值必须用单引号括起来 每个文字字符串在每行输出一次 SELECT last_name| is a |job_id AS “Employee Details” FROM employees;,约束和排序数据,目标,完成本课后, 您应当能够执行下列操作: 用一个查询限制返回的行 用一个查询分类

6、返回的行,限制选择的行,用WHERE子句限制返回的行 SELECT * |DISTINCT column|expressionalias,. FROM table WHERE condition(s); WHERE子句跟着FROM子句 WHERE 限制查询满足条件的行 condition 由列名、表达式、常数和比较操作组成 WHERE子句能够比较列值、文字值、算术表达式或者函 数,WHERE子句由三个元素组成: 列名 , 比较条件 , 列名、常量或值列表 。,使用WHERE子句,SELECT employee_id, last_name, job_id, department_id FROM

7、employees WHERE department_id = 90 ;,字符串和日期,字符串和日期的值放在单引号中 字符值区分大小写,日期值是格式敏感的 日期的默认格式是DD-MON-RR. SELECT last_name, job_id, department_id FROM employees WHERE last_name = Whalen;,比较条件,运算 含义 = 等于 大于 = 大于等于 不等于 比较条件被用于一个表达式与一个值或与另一个表达式的比较。 . WHERE hire_date=01-JAN-95 . WHERE salary=6000 . WHERE last_na

8、me=Smith,其它比较条件,操作 含义 BETWEEN.AND. 在两个值之间(包含) IN(set) 匹配一个任意值列表 LIKE 匹配一个字符模板 IS NULL 是一个空值 使用BETWEEN条件: SELECT last_name, salary FROM employees WHERE salary BETWEEN 2500 AND 3500; 使用IN条件 SELECT employee_id, last_name, salary, manager_id FROM employees WHERE manager_id IN (100, 101, 201);,其它比较条件,使用L

9、IKE条件 使用LIKE条件执行有效搜索串值的通配符搜索 搜索条件既可以包含文字也可以包含数字: %表示任意顺序的零个或多个字符 _表示一个字符 SELECT first_name FROM employees WHERE first_name LIKE S%; 使用NULL条件 用IS NULL操作来测试空值 SELECT last_name, manager_id FROM employees WHERE manager_id IS NULL; NULL条件,包括IS NULL条件和IS NOT NULL条件。,逻辑条件,运算 含义 AND 如果两个组成部分的条件都为真,返回TRUE OR

10、 如果两个组成部分中的任一个条件为真,返回TRUE NOT 如果跟随的条件为假,返回TRUE 可以在WHERE子句中用AND和OR运算符使用多个条件。 使用AND操作:AND要求两个条件同时为真 SELECT employee_id, last_name, job_id, salary FROM employees WHERE salary =10000 AND job_id LIKE %MAN%;,逻辑条件,使用OR操作:OR操作要求两者之一为真即可 SELECT employee_id, last_name, job_id, salary FROM employees WHERE sala

11、ry = 10000 OR job_id LIKE %MAN%; 使用NOT操作 SELECT last_name, job_id FROM employees WHERE job_id NOT IN (IT_PROG, ST_CLERK, SA_REP); 注:NOT运算符也可以用于另一个SQL运算符,例如,BETWEEN、LIKE、和NULL。,优先规则,求值顺序 1 算术运算 2 连字操作 3 比较操作 4 ISNOTNULL, LIKE, NOTIN 5 NOT BETWEEN 6 NOT逻辑条件 7 AND逻辑条件 8 OR逻辑条件 使用圆括号改变优先规则,ORDER BY子句,用O

12、RDER BY子句排序行 ASC: 升序排序,默认 DESC: 降序排序 ORDER BY子句在SELECT语句的最后 SELECT last_name, job_date FROM employees ORDER BY hire_date ; 语法 : SELECT expr FROM table WHERE condition(s) ORDER BY column, expr ASC|DESC;,单行函数,目标,完成本课后,您应当能够执行下列操作: 描述在SQL 中可用的函数的变量类型 在SELECT语句中使用字符,数字和日期函数 描述转换函数的使用,SQL 函数,函数是SQL的一个非常强

13、有力的特性,函数能够用于下面的目的: 执行数据计算 修改单个数据项 操纵输出进行行分组 格式化显示的日期和数字 转换列数据类型 SQL函数有输入参数,并且总有一个返回值。 注:在本课中讲述的大多数函数是针对SQL的Oracle版的。,SQL 函数 (续),有两种截然不同的函数: 单行函数 多行函数 单行函数 这些函数仅对单个行进行运算,并且每行返回一个结果。有不同类型的单行函数,本课下面的函数类型: 字符 数字 日期 转换 多行函数 这些函数能够操纵成组的行,每个行组给出一个结果,这些函数也被称为组函数。多行函数在后面的课程中介绍。,单行函数,单行函数: 操纵数据项 接受多个参数并返回一个值

14、作用于每一个返回行 每行返回一个结果 可以修改数据类型 可以嵌套 接受多个参数,参数可以是一个列或者一个表达式,单行函数(续),单行函数的特性包括: 作用于查询中返回的每一行 每行返回一个结果 可能返回一个与参数不同类型的数据值 可能需要一个或多个参数 能够用在SELECT、WHERE和ORDER BY子句中,可以嵌套 。 function_name(arg1, arg2,.) function_name 是函数的名字。 arg1, arg2 是由函数使用的任意参数,可以由一个列名或者一个表达式提供。,单行函数(续),本课包括下面的单行函数: 字符函数:接受字符输入,可以返回字符或者数字值 数

15、字函数:接受数字输入,返回数字值 日期函数:对DATE数据类型的值进行运算 (除了MONTHS_BETWEEN函数返回一个数字,所有日期函数都返回一个DATE数据类型的值。) 转换函数:从一个数据类型到另一个数据类型转换一个值 通用函数: NVL 、 NVL2、 NULLIF、 COALSECE、 CASE 、 DECODE,字符函数,单行字符函数接受字符数据作为输入,既可以返回字符值也 可以返回数字值。字符函数可以被分为下面两种: 大小写处理函数 字符处理函数 大小写处理函数如下: LOWER(column|expression) 转换字符值为小写 UPPER(column|expression) 转换字符值为大写 INITCAP(column|expression) 转换每个单词的首字母值为大写,所有 其它值为小写 字符处理函数如下: CONCAT(column1|expression1 ,column2|expression2) 连接第一个字符值到第二个字符值;等价于连

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号