四、Oracle 序列、常用函数、多表连接
一.序列
定义:是oracle数据库专门用来产生连续且自动增长的数字的对象
创建语法:create sequence 序列名(sq_表名) nocache(无缓存)
create sequence sq_student nocache
使用方法:通过两个属性来访问:nextval(下一个值),currval(当前值)
使用场景:一般是用来维护主键的自动增长:
insert into student_info values(sq_student.nextval,'哈哈',1,22,null)
二.常用函数:
1.字符函数:
Lower:转换小写
upper:转换大写
length:获取字符串长度
nvl:空值转换
2.数字函数
round:四舍五入的取整
trunc:截取取整,不四舍五入
mod:取余运算 mod(5,2) = 1
3.日期函数:
trunc(日期):截取日期的年月日部分。
4.转换函数:
to_char:转换成字符串 to_char(日期,'yyyy/MM/dd')
to_date:转换成日期
to_number:转换成数字
例:
select sq_student.nextval from dual
select sq_student.currval from dual select * from student_info where length(student_name)=2 insert into student_info values(sq_student.nextval,'哈哈',1,22,null) select lower('ABVCDFG') from dual select * from score_info where trunc(score_time)=to_date('2017/12/4','yyyy/MM/dd') select * from score_info where to_char(trunc(score_time),'yyyy/MM/dd')='2017/12/04' select add_date(score_time,2) from score_info insert into score_info values(3,1,100,sysdate,2) select to_char(trunc(score_time),'yyyy/MM/dd') from score_info select to_number('abc') from dual
三.多表连接
作用:是从多表中去获取数据
1.内连接:
特点:只显示完全匹配的数据
语法:
select a.class_name,b.stu_name,b.stu_age from classinfo a, student b
where a.class_id=b.class_id;
select a.class_name,b.stu_name,b.stu_age from classinfo a inner join student b
on a.class_id=b.class_id;
2.外连接:
会有主从关系,主表信息全部显示,从表中匹配不上的信息以null显示
a.左外联:left join ...on...
b.右外联:right join ...on...
c.全外联:full outer join ...on...
d:简易写法:(+) 加号在哪边,哪边就是从表,加号表示1~多
案例:
select a.class_name,b.stu_name,b.stu_age from student b ,classinfo a
where b.class_id(+)=a.class_id;
select a.class_name,b.stu_name,b.stu_age from classinfo a full outer join student b
on a.class_id=b.class_id;
3.集合操作
注意:必须是两个查询结果集列数和数据类型相匹配
a.union:拼接两个结果集,去除重复数据
b.union all:完全拼接,不去除重复
c.minus:集合1减去交集部分
d.intersect:取交集部分
4.oracle数据库的sequence(序列)
作用:用来生成连续的且唯一的数字序列,一般用来维护主键
创建序列:create sequence 序列名 nocache 不使用缓存
使用:序列名.currval访问当前值 序列名.nextval获取下一个值
维护主键:insert into classinfo values(seq_classinfo.nextval,'ui1班',1)
5.oracle的伪列(常用来做分页)
a.rownum:反应查询结果集的行序号,用来做行数条件查询
例子:select * from (select stu_name,rownum num_ from student) a where a.num_>=3 and a.num_<=5
b.rowid:是当前行的内存地址
作业:
1.创建四张表:
班级信息表:主键,班级名
学员信息表:主键,姓名,性别,年龄,班级外键
科目信息表:主键,科目名
成绩信息表:主键,成绩,考试时间,学员外键,科目外键
关系:班级和学员1对多,科目和成绩 1对多 学员和成绩是1对多
2.插入数据:用序列来维护主键
班级表两条数据 (1.java1班 2.java2班)
学员表十条数据,其中有两条班级外键为null
科目表4条数据 (1.java 2.oracle 3.j2ee 4.html)
成绩表20条数据,其中有两条数据学员外键为null,然后4号科目没有成绩信息,不一定每一个人都有考试成绩
3.查询
a.查询得到如下报表
班级名 学员名 科目名 成绩 考试时间
b.查询java1班谁没有参加oracle考试的学员信息
select b.class_name,a.student_name,c.score_grade,d.project_name from student_info a
inner join class_info b on a.class_id=b.class_id and b.class_name='java6班'
left join score_info c on a.student_id = c.student_id
inner join project_info d on c.project_id = d.project_id and
d.project_name='java' and c.score_grade is null
c.查询java2班的j2ee考试成绩信息
班级名 学员名 科目名 成绩
d.查询还没有分班的学员信息
e.查询作废的成绩信息,即找不到匹配学员信息的成绩
f.查询考试时间为'2017-7-1'这天的java1班的java考试成绩信息
班级名 学员名 科目名 成绩 考试时间
g.查询成绩信息第10条到20条的数据
select * from (select rownum num_,a.* from score_info a) t where t.num_>=2 and t.num_<=3
四、Oracle 序列、常用函数、多表连接的更多相关文章
- 单行函数、表连接(day02)
回顾: 1.数据库介绍 sql: dql: select dml: insert delete update ddl: create drop alter tcl: commit rollback s ...
- Oracle数据库常用函数
Oracle常用函数: 20.COS返回一个给定数字的余弦SQL> select cos(-3.1415927) from dual;COS(-3.1415927)--------------- ...
- 【Oracle】常用函数
来源自:https://www.cnblogs.com/lxl57610/p/7442130.html Oracle SQL 提供了用于执行特定操作的专用函数.这些函数大大增强了 SQL 语言的功能. ...
- Oracle 之 常用函数
SQL语句根据参数的不同,分为单行函数 和 多行函数. [1] 单行函数:输入是一行,输出也是一行: [2] 多行函数:输入多行数据,输出一个结果. 在执行时,单行函数是检索一行处理一次,而多行函数是 ...
- Oracle开发常用函数与存储过程
create or replace function Fuc_Get_AuthorName(RecID_In in varchar2, AdmID_In in varchar2) return var ...
- oracle的常用函数
1. nvl NVL函数的格式如下:NVL(expr1,expr2) 含义是:如果oracle第一个参数expr1为空,那么显示第二个参数的值为expr2,如果第一个参数的值expr1不为空,则显示第 ...
- [转载]oracle的常用函数 instr() 和substr()函数
在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找指定的字符,返回被查找到的指定的字符的位置. 语法: instr(sourceString, ...
- oracle的常用函数 instr() 和substr()函数
from:http://1055592535.iteye.com/blog/1676235 在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找 ...
- Oracle DBA常用的系统表
1.2 DBA常用的表1.2.1 dba_开头 dba_users数据库用户信息 dba_segments 表段信息 dba_extents 数据区信息 dba_ob ...
- oracle中常用函数
1.oracle中 trunc 是截取的函数,用在日期类型上,就是截取到的日或时间. select trunc(sysdate) from dual 默认是截取系统日期到日,得到 2012-12- ...
随机推荐
- 6;XHTML 超链接
1.超链接的基本格式 2.超链接的种类 3.相对链接和绝对链接 4.书签的链接 5.基准参考点 6.超链接事件 7.为链接创建键盘快捷键 8.为链接设置制表符次序 超链接也叫 URL 中文翻译为资源定 ...
- 2; HTML 基本结构
1. HTML 的基本结构 2. HTML 控制标记的格式 3. 最常用的控制标记 本章讲解最基本的 HTML 元素,也就是创建文档结构所需的元素.例如:标题.段落. 页面分隔.注释等等. 2.1 H ...
- link-hover-visited-active
:link { color: blue; } :visited { color: purple; } :hover { color: red; } :active { color: orange; } ...
- 微信小程序使用wxParse,解决图片显示路径问题
我们经常用到发布文章,用的是UEditor百度富文本编辑器,方便排版,存储的也是html代码,这样小程序解析出来的也是排版的样式,但是使用wxParse解析html的时候,因为存储的是图片的相对路径, ...
- 极简】如何在服务器上安装SSL证书?
本文适合任何人了解,图形化操作.下面以腾讯云为例,并且服务器(linux)也安装了宝塔面板. 1.登陆腾讯云账号进入控制台,找到SSL的产品 2.按要求申请并填写表单,记住私钥密码 3.提交后,待腾讯 ...
- Windows 不能在本地计算机启动 OracleDBConsoleorcl的问题解决方法
解决步骤如下: 1.开始->运行cmd 2.执行 emctl start dbconsole 输入:C:\Documents and Settings\xcl>emctl start db ...
- Python 实现批量从不同的Linux服务器下载文件
基于Python实现批量从不同的Linux服务器下载文件 by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/file_for_downl ...
- recovery 下界面UI旋转90 180 270修改
原文修改出自简书:https://www.jianshu.com/p/768fdd954061 应该是MTK修改的google源码,支持recovery下屏幕旋转90/180/270, 作者把MTK的 ...
- LeetCode题解之Clone Graph
1.题目描述 2.问题分析 要遍历图,然后标记没有被复制的节点. 3.代码 class Solution { private: unordered_map<Node*, Node*> m; ...
- Java读取.properties配置文件
一.介绍 Properties文件在Java中主要为配置文件,文件类型为:.properties,格式为文本文件,内容格式为"键=值" 二.读取 这里我采用的是getResourc ...