Oracle数据库 | 基于SQL基础分析

简介: Oracle数据库 | 基于SQL基础分析

创建表空间


SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计。Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献。可以这么说,Oracle中很多优化都是基于表空间的设计理念而实现


表空间作用

  • 决定数据库实体的空间分配
  • 设置数据库用户的空间份额
  • 控制数据库部分数据的可用性
  • 分布数据于不同的设备之间以改善性能
  • 备份和恢复数据


表空间管理


  • 查看系统当前用户
select * from user_users;   
  • 查询表空间
select * from sys.dba_tablespaces;
select tablespace_name from dba_tablespaces;
  • 删除表空间
drop tablespace 表空间名 including contents and datafiles ;
  • 修改表空间自动扩展大小
alter database datafile 'E:\JetBrains\DG\Data\waterboss.dbf' autoextend on next 100m;
  • 修改表空间大小
alter database datafile 'E:\JetBrains\DG\Data\waterboss.dbf' resize 1024m;
  • 创建临时表空间
create temporary tablespace tmp_tbs2 tempfile 'E:\JetBrains\DG\Data\tmp_tbs2' size 100m;
  • 创建用户,指定默认表空间,指定临时表空间,指定配额
create user test1 identified by "123456"
    default tablespace tbs2     -- 指定默认表空间
    temporary tablespace tmp_tbs2   -- 指定临时表空间
    quota 500 on tbs2;      -- 指定配额

创建表空间

-- 创建表空间
create tablespace waterboss     -- 创建表空间waterboss
datafile 'E:\JetBrains\DG\Data\waterboss.dbf'   -- 数据文件位置
size 100m   -- 指定数据文件大小
autoextend on next 10m;      -- 指定数据文件存满后自动扩展内存大小
  • tablespace 指定表空间名
  • datafile 指定数据文件位置
  • size 设置表空间大小
  • autoextend on 用于设置自动增长,如果储存量超过初始大小,则开始自动扩容
  • next 用于设置扩容表空间大小

创建用户与赋权


创建用户与赋权


  • 创建用户后需要使用grant命令给用户授权才能登陆用户
-- 创建用户
create user wateruser
identified by itcast
default tablespace waterboss;
-- 删除用户
drop user TEST1 cascade ;
-- 创建用户权限
grant dba to wateruser;
  • wateruser 创建的用户名
  • identified by 用于设置用户的密码
  • default tablespace 用于指定默认表空间名称
  • grant dba to wateruser; 给用户wateruser赋予DBA权限即可登录


表的创建 | 修改 | 删除


  • 表的创建
create table 表名(
  ...
);
create table user01(
  id int,
  name varchar(20),
  address varchar(20)
);
  • 表的修改
-- 语法:alter table 表名 add 列名 类型(长度)[约束];
alter table mydb1 add id varchar(20);
  • 表的删除
-- 语法:drop table 表名;
drop table student;

数据的增 | 删 | 改 | 查


  • 数据的增添(insert)


1.向表中插入某些 insert into 表(列1,列2,列3…) value(值1,值1,值1…);
2.向表中插入所有列 insert into 表 value(值1,值1,值1…);
insert into stu(sid,name,gender,age,birth,address,score)
        values(001,"一一","男",18,"2002-11-25","武汉",100),
        (002,"二二","女",10,"2002-10-21","武汉",80),
        (003,"三三","女",10,"2002-10-21","武汉",70);
insert into stu values(004,"六六","男",40,"2002-10-21","武汉",80);
  • 数据的删除(delete)
    delete 只删除内容
    truncate类似于drop table 删除表(删除表内容结构)
delete from 表名 [where 条件];
truncate table 表名 或者 truncate 表名
delete from stu where sid = 11;
delete from stu;
truncate table stu;
truncate stu;
  • 数据的修改(update)
update 表名 set 字段名=值,字段名=值…;
update 表名 set 字段名=值,字段名=值… where 条件;
update stu set address = '武汉';            
update stu set address = '北京' where sid = 001;            
update stu set address = '上海' where sid >= 5;       
update stu set address = 'wuhan' , score = 0 where sid = 10;
  • 数据的查询(select)
-- 语法:select * from 表名;
select * from student;    -- 查询学生表的所有内容

伪列查询


Oracle表的使用过程中,实际表中还有一些附加的列,称为伪列。伪列就像表中的列一样,但是表中并不存储。伪列只能查询,不能进行增删改操作


ROWID


  • 表中每一行在数据文件中都有一个物理地址,ROWID伪列返回的就是该行的物理地址
  • 使用ROWID可以快速定位表中某一行,ROWID值可以唯一的标识表中一行
  • ROWID返回的是该行的物理地址,因此使用ROWID可以显示是如何存储的


查询语句

select rowid,t.* from T_AREA t;

ROWNUM


查询结果集中,ROWNUM为结果集中每一行标识一个行号,通过ROWNUM伪列可以限制查询结果集中返回的行数


查询语句

select rownum,t.* from T_OWNERTYPE t;

约束

主键约束——primary key

主键约束在表中定义一个主键来唯一确定表中每一行数据的标识符,要求主键列数据唯一,并且不允许为空


  • 创建主键约束
-- 单列主键
create table 表名(
  ...
  <字段名><数据类型>primary key
    ...
);
-- 多列主键
create table 表名(
  ...
    primary key(字段1,字段2,...)
);
  • 修改主键约束
-- 修改表结构添加主键
create table 表名(
  ...
);
alter table <表名> add primary key(字段列表);
  • 删除主键约束
alter table <数据表名> drop primary key;

外键约束——foreign key

外键约束主要是在父子表关系中体现的一种约束操作,用于在两个表之间建立关系,需要指定引用主表的哪一列


  • 创建外键约束
constraint 外键名 foreign key (从表的外键字段名) references 主表名 (主表的主键字段名)
  • 方式一:创建表时设置外键约束
create table if not exists emp(
  eid varchar(20) primary key,
  ename varchar(20),
  age int,
  dept_id varchar(20),
  constraint emp_fk foreign key (dept_id) references dept (detpno)
);
  • 方式二:创建表后设置外键约束
alter table 从表名 add constraint 外建名 foreign key (从表的外键字段名) references 主表名 (主表的主键字段名);
  • 删除外键约束
alter table <数据表名> drop foreign key 外键名;

非空约束——not null


  • 方式一:创建表时指定
语法:<字段名><数据类型> not null;
create table user04(
  id int,
  name varchar(20) not null,
  address varchar(20) not null
);
insert into user04(id,name,address) values(1001,'一一','武汉');
insert into user04(id,name,address) values(1001,null,null);
insert into user04(id,name,address) values(1001,'','');
  • 方式二:创建表之后指定
语法:alter table 表名 modify 字段 not null;
use mydb3;
create table user05(
  id int,
  name varchar(20) not null,
  address varchar(20) not null
);
alter table user05 modify name varchar(20) not null;
alter table user05 modify address varchar(20) not null;
desc user05;    -- 查看表结构
insert into user05(id,name,address) values(1001,'魏硕','武汉');
insert into user05(id,name,address) values(1001,null,null);
insert into user05(id,name,address) values(1001,'','');
  • 删除非空约束
语法:alter table 表名 modify 字段 类型
alter table user05 modify name varchar(20);
alter table user05 modify address varchar(20);
目录
相关文章
|
10天前
|
SQL 存储 关系型数据库
【SQL技术】不同数据库引擎 SQL 优化方案剖析
不同数据库系统(MySQL、PostgreSQL、Doris、Hive)的SQL优化策略。存储引擎特点、SQL执行流程及常见操作(如条件查询、排序、聚合函数)的优化方法。针对各数据库,索引使用、分区裁剪、谓词下推等技术,并提供了具体的SQL示例。通用的SQL调优技巧,如避免使用`COUNT(DISTINCT)`、减少小文件问题、慎重使用`SELECT *`等。通过合理选择和应用这些优化策略,可以显著提升数据库查询性能和系统稳定性。
64 9
|
21天前
|
SQL Oracle 关系型数据库
如何在 Oracle 中配置和使用 SQL Profiles 来优化查询性能?
在 Oracle 数据库中,SQL Profiles 是优化查询性能的工具,通过提供额外统计信息帮助生成更有效的执行计划。配置和使用步骤包括:1. 启用自动 SQL 调优;2. 手动创建 SQL Profile,涉及收集、执行调优任务、查看报告及应用建议;3. 验证效果;4. 使用 `DBA_SQL_PROFILES` 视图管理 Profile。
|
28天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
91 6
|
1月前
|
关系型数据库 分布式数据库 数据库
瑶池数据库大讲堂|PolarDB HTAP:为在线业务插上实时分析的翅膀
瑶池数据库大讲堂介绍PolarDB HTAP,为在线业务提供实时分析能力。内容涵盖MySQL在线业务的分析需求与现有解决方案、PolarDB HTAP架构优化、针对分析型负载的优化(如向量化执行、多核并行处理)及近期性能改进和用户体验提升。通过这些优化,PolarDB HTAP实现了高效的数据处理和查询加速,帮助用户更好地应对复杂业务场景。
|
2月前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
95 11
|
2月前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
140 11
|
2月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
2月前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
3月前
|
SQL 存储 BI
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
|
3月前
|
SQL 数据库
gbase 8a 数据库 SQL优化案例-关联顺序优化
gbase 8a 数据库 SQL优化案例-关联顺序优化

推荐镜像

更多