百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Oracle数据库知识 day01 Oracle介绍和增删改查

wptr33 2025-07-09 18:01 5 浏览

一、 oracle介绍

ORACLE 数据库系统是美国 ORACLE 公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或 B/S 体系结构的数据库之一。比如 SilverStream 就是基于数据库的一种中间件。ORACLE 数据库是目前世界上使用最为广泛的数据 库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库, 它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。但它的所有知识,只要在一种机型上学习了 ORACLE 知识,便能在各种类型的机器上使用它。


二、 Oracle安装


三、 Oracle体系结构

3.1 数据库:

Oracle 数据库是数据的物理存储。这就包括(数据文件 ORA 或者 DBF、控制文件、联机日志、参数文件)。其实 Oracle 数据库的概念和其它数据库不一样,这里的数据库是一个操作系统只有一个库。可以看作是 Oracle 就只有一个大数据库。


3.2 实例:

一个 Oracle 实例(Oracle Instance)有一系列的后台进程(Backguound Processes)和内存结构 (Memory Structures)组成。一个数据库可以有 n 个实例。


3.3 用户:

用户是在实例下建立的。不同实例可以建相同名字的用户。


3.4 表空间:

表空间是 Oracle 对物理数据库上相关数据文件(ORA 或者 DBF 文件)的逻辑映射。一个数据库在逻辑上被划分成一到若干个表空间,每个表空间包含了在逻辑上相关联的一组结构。每个数据库至少有一个表空间(称之为 system 表空间)。 每个表空间由同一磁盘上的一个或多个文件组成,这些文件叫数据文件(datafile)。一个数据文件只能属于一个表空间。


3.5 数据文件(dbf、ora)

数据文件是数据库的物理存储单位。数据库的数据是存储在表空间中的,真正是在某一个或者多个数据文件中。而一个表空间可以由一个或多个数据文件组成,一个数据文件只能属于一个表空间。一旦数据文件被加入到某个表空间后,就不能删除这个文件,如果要删除某个数据文件,只能删除其所属于的表空间才行。

注: 表的数据,是有用户放入某一个表空间的,而这个表空间会随机把这些表数据放到一个或者多个数据文件中。 由于 oracle 的数据库不是普通的概念,oracle 是有用户和表空间对数据进行管理和存放的。 但是表不是有表空间去查询的,而是由用户去查的。因为不同用户可以在同一个表空间建立同一个名字的表!这里区分就是用户了!


3.6 oracle数据库的数据结构图示:


四、 创建表空间

表空间是ORACLE数据库的逻辑单元。一个表空间可以与多个数据文件(物理结构)关联。一个数据库下可以建立多个表空间,一个表空间可以建立多个用户、一个用户下可以建立多个表。

创建表空间的命令:

create tablespace itcast

datafile 'c:\itcast.dbf'

size 100m

autoextend on

next 10m

解析:

itcast 为表空间名称

datafile 指定表空间对应的数据文件

size 定义表空间的初始大小

autoextend on 当表空间存储都占满时,自动增长

next 一次自动增长的大小。


五、 用户

5.1 创建用户

create user itcastuser

identified by itcast

default tablespace itcast

解析:

identified by 后边是用户的密码

default tablespace 后边是表空间名称


oracle 数据库与其它数据库产品的区别在于,表和其它的数据库对象都是存储在用户 下的。


5.2 用户赋权限

Oracle 中已存在三个重要的角色:connect 角色,resource 角色,dba 角色。 connect 角色:是授予用户的典型权利

resource 角色: 是授予开发人员的

dba 角色:拥有全部特权,是系统最高权限,只有 DBA 才可以创建数据库结构,并且系统权限也需要 DBA 授出,且 DBA 用户可以操作全体用户的任意基表,包括删除


赋权限命令:grant dba to itcastuser 给用户赋予dba权限


六、Oracle数据类型


七、 表的管理

7.1 建表


7.2 删除表

语法:DROP TABLE 表名


7.3 修改表结构


7.4 数据库表数据的更新

7.4.1 INSERT(增加)


7.4.2 UPDATE(修改)

全部修改:UPDATE 表名 SET 列名 1=值 1,列名 2=值 2,....

局部修改:UPDATE 表名 SET 列名 1=值 1,列名 2=值 2,....WHERE 修改条件;


7.4.3 DELETE(删除)

语法 : DELETE FROM 表名 WHERE 删除条件;

在删除语句中如果不指定删除条件的话就会删除所有的数据


7.4.4 注意事项: 因为 oracle 的事务对数据库的变更的处理,我们必须做提交事务才能让数据真正的插入到数据库中,在同样在执行完数据库变更的操作后还可以把事务进行回滚,这样就不会插入到数据库。如果事务提交后则不可以再回滚。

提交:commit

回滚:rollback


7.5 序列

在很多数据库中都存在一个自动增长的列,如果现在要想在 oracle 中完成自动增长的功能, 则只能依靠序列完成,所有的自动增长操作,需要用户手工完成处理。

语法:CREATE SEQUENCE 序列名

序列创建完成之后,所有的自动增长应该由用户自己处理,所以在序列中提供了以下的两种操作:

nextval :取得序列的下一个内容

currval :取得序列的当前内容

举例:

CREATE SEQUENCE seqpersonid;

select seqpersonid.nextval from dual;

select seqpersonid.currval from dual;

在实际项目中每一张表会配一个序列,但是表和序列是没有必然的联系的,一个序列被哪 一张表使用都可以,但是我们一般都是一张表用一个序列。


八、单行函数

8.1 字符函数

8.1.1 把小写字符转换成大写字符:upper('smith')


8.1.2 把大写字符变成小写字符: lower('SMITH')


8.2 数值函数

8.2.1 四舍五入函数:ROUND()

默认情况下 ROUND 四舍五入取整,可以自己指定保留的位数。


8.3 日期函数

8.3.1 日期的加减:

日期 – 数字 = 日期

日期 + 数字 = 日期

日期 – 日期 = 数字


8.3.2 获得两个时间段中的月数:MONTHS_BETWEEN()

范例:查询所有雇员进入公司的月数

select ename, round(MONTHS_BETWEEN(sysdate,hiredate)) from emp


8.4 转换函数

8.4.1 TO_CHAR:字符串转换函数


8.4.2 TO_DATE:日期转换函数,可以把字符串的数据转换成日期类型


8.5 通用函数

8.5.1 空值处理 nvl


8.5.2 Decode 函数


8.5.3 case when


九、 多行函数(聚合函数)

9.1 统计记录数 count()


9.2 最小值查询 min()


9.3 最大值查询 max()


9.4 查询平均值 avg()


9.5 求和函数 sum()


十、分组统计

分组统计需要使用 GROUP BY 来分组

语法:SELECT * |列名 FROM 表名 {WEHRE 查询条件} {GROUP BY 分组字段} ORDER BY 列 名 1 ASC|DESC,列名 2...ASC|DESC


十一、 多表查询

11.1 多表连接基本查询

使用一张以上的表做查询就是多表查询

语法: SELECT {DISTINCT} *|列名.. FROM 表名 别名,表名 1 别名 {WHERE 限制条件 ORDER BY 排序字段 ASC|DESC...}


11.2 外连接(左右连接)

使用(+)表示左连接或者右连接,当(+)在左边表的关联条件字段上时是左连接,如果是在右边表的关联条件字段上就是右连接。



十二、 子查询

12.1 子查询:在一个查询的内部还包括另一个查询,则此查询称为子查询。 Sql的任何位置都可以加入子查询。


12.2 子查询在操作中有三类:

单列子查询:返回的结果是一列的一个内容

单行子查询:返回多个列,有可能是一个完整的记录

多行子查询:返回多条记录


12.3 实例:

相关推荐

搭建Oracle数据库服务器(oracle数据库服务器安装教程)

【十一】搭建Oracle数据库服务器...

Oracle 删除大量表记录操作总结(oracle删除表记录数据)

删除表数据操作清空所有表记录TRUNCATETABLEyour_table_name;...

专访搜狗DBA负责人王林平:为何从Oracle转向MySQL?

王林平CSDN:首先,请做个自我介绍,目前所负责的领域以及所在公司。王林平:大家好,我是王林平,目前在搜狗商业平台研发部工作。主要负责商业广告数据库的维护、优化、架构设计、流程体系建设、自动化运维平台...

Oracle数据库知识 day01 Oracle介绍和增删改查

一、oracle介绍ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构...

深入探索Oracle 回表原理、影响与优化技巧

什么是回表当对一个列创建索引之后,索引会包含该列的键值以及键值对应行所在的rowid。通过索引中记录的rowid访问表中的数据就叫回表。执行计划中的TABLEACCESSBYINDEXROW...

那些年我们踩过的语句创建oracle 12c cdb实例的坑

现在大多数客户使用oracle还是11g版本的,很多小伙伴可能还没接触过12c,所以今天小编要为大家科普下12c版本的oracle的安装过程中会出现的错误。前面步骤其实都是一样的,我们就直接从建好1...

Oracle高级数据库特性揭秘:存储过程、触发器与权限管理

当谈论Oracle高级数据库特性时,存储过程和函数、触发器、权限管理和安全性以及数据库连接和远程访问是关键概念。下面我将为每个主题提供详细的解释,并附上高质量示例。...

ORACLE内核解密之表空间管理(oracle表空间大小是由什么决定)

一、ORACLE表空间管理1、本地表空间管理tablespace(LMT)...

Oracle 创建磁盘组报错ORA-15137的问题分析与解决思路

ASM扩容本来是件很简单的事,当ASM磁盘准备好之后,直接一条命令就会添加上。但是也会有异常情况,最近就碰到Oracle19c在扩容时报错的故障,供大家参考。...

DBA日记之Oracle数据库索引一(oracle数据库索引有哪几种)

什么是索引在oracle数据库中,索引是数据库中一种可选的数据结构,通常与表或簇相关。用户可以在表的一列或数列上建立索引,以提高在此表上执行SQL语句的性能。就像本文档的索引可以帮助读者快速定位所...

利用Oracle触发器实现不同数据库之间的数据同步

首先在两个数据库之间创建链接(DBLink),然后对要同步地表做一个同义(synonym),最后建一个触发器实现同步。实现步骤如下:1)为保证连接到另一台远程服务器的数据库,需要建立一个DBLin...

oracle已有表的分表分区优化操作步骤(单表过大)

第一章、步骤总览0、获取创建表空间DDL、创建表空间(该步骤在将分区放入不同的表空间时采用)...

Oracle 表分区在线重定义(oracle表分区后查询语句改变吗)

表分区有以下优点:a、改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度。b、增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;c、维护方便:如果表的某个分区出现故障...

ORACLE 体系 - 14(oracle 11g的体系结构有几种)

【十四】数据移动...

Oracle-架构、原理、进程(oracle进程结构)

详解:首先看张图:对于一个数据库系统来说,假设这个系统没有运行,我们所能看到的和这个数据库相关的无非就是几个基于操作系统的物理文件,这是从静态的角度来看,如果从动态的角度来看呢,也就是说这个数据库系统...