数据库(mysql oracle)学习小结

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 数据库概念 oracle数据库 一组:数据文件、控制文件、日志文件 oracle实例,它与数据库的关系 oracle实例:实例就是数据库启动后分配的内存和建立的后台进程. 数据库关闭后,物理上的文件还存在,但实例(分配的内存和建立的进程)就没有了 数据库:物理操作系统文件或磁盘(disk)的集合。 关系:  实例就是一组操作系统进程(或者是一个多线程的进程)以及一些内存。这些进
数据库概念
oracle数据库
一组:数据文件、控制文件、日志文件

oracle实例,它与数据库的关系
oracle实例:实例就是数据库启动后分配的内存和建立的后台进程. 数据库关闭后,物理上的文件还存在,但实例(分配的内存和建立的进程)就没有了
数据库:物理操作系统文件或磁盘(disk)的集合。

关系:  实例就是一组操作系统进程(或者是一个多线程的进程)以及一些内存。这些进程可以操作数据库;而数据库只是一个文件集合(包括数据文件、临时文件、重做日志文件和控制文件)。
    在任何时刻,一个实例只能有一组相关的文件(与一个数据库关联)。大多数情况下,反过来也成立:一个数据库上只有一个实例对其进行操作。
    不过,Oracle的真正应用集群(Real Application Clusters,RAC)是一个例外,这是Oracle提供的一个选项,允许在集群环境中的多台计算机上操作,
    这样就可以有多台实例同时装载并打开一个数据库(位于一组共享物理磁盘上)。


数据库中的数据类型:
数字:mysql db2-----short integer long float double
      oracle--------number(30),number(30,3)
字符/字符串:char(10)     varchar2(10)
日期和时间:date(年、月、日、小时、分钟、秒) timestamp()(时间戳)
oracle数据库模式日期格式:03-3月-08   03-Mar-08
大对象(Characterlob/Binary lob)


主键应该具备的特征:
1.不能为null
2.主键必须唯一

where name like '\%' escape '\'

字符:
upper
lower
initcap
substr
replace
instr
length
lpad/rpad
trim
concat--------||

select substr(last_name,1,1)||lpad(last_name,sbustr(last_name,2,length(last_name)-1,'*')

replace(last_name,substr(last_name,2,leghth(last_name)-2),lpad('',length(last_name)-2,'*')

日期:
months_between
add_months()
next_day()
last_day()

数字:
round(2333,2)
trunc
mod

round(sysdate,'month/year')

类型转换的函数
to_char to_date to_number

to_char(数字/日期,'fm')

to_char(sysdate,'fmyyyy-mm-dd "fdfdfdfd" HH24:MI:SS am')


to_char(234567,'fm99,999.00000')


to_date('20-3月-58')
to_date('[2008-02-08]','[yyyy-mm-dd]')

RR
68

通用函数:
nvl(commission_pct,0)----第一个表达式为null,返回第二个表达式的值,否则返回第一个表达式的值
nvl(commission_pct,1,0)--第一个表达式为null,返回第三个表达式的值,否则返回第二个表达式的值
nullif(last_name,first_name)--如果第一个表达式和第二个表达式的值相同,返回null,否则返回第一个表达式的值
decode()


lpad('',round((salary*12+salary*12*nvl(commission_pct,0))/1000),'*')

多表的查询两种方法:
连接查询
内连接:等值连接、非等值连接、自然连接。。。
外连接:左、右、全外连接

笛卡尔集----子集
select * from users u,orders o where u.id=o.user_id and ;
select * from users u join orders o on u.id=o.user_id;

cross join

select a.dd,b.dd,c.dd from A a,B b,c c where a.pk=b.id and b.id=c.fk

employee
1 A  500
2 B 660
3 c 1000
4 d 4000

level
id name minsalary maxsalay
1 A级   5000       10000
2 B级   3000       5000
3 C级   1000       3000
4 D级   400        1000

A  D级
B  D级
C  C级
D  B级

select e.name,l.name from employee e,level l where e.salary between l.minsalary and l.maxsalary;

1 A 500 4 D级   400        1000
2 B 660 4 D级   400        1000
3 C 1000 3 C级   1000       3000
4 d 4000 2 B级   3000       5000



select * from users u left/right/full outer join orders o on u.id=o.user_id;


Oracle写外连接的简便的方式:
select * from users u,orders o where u.id(+)=o.user_id;


select * from departments nature join loctions------两个表的主外键必须同名,同类型
同名,类型不一致
select * from deparments join locations using(location_id);


select * from departments d,locations l where d.location_id=l.locations_id;

select e.last_name,e.job_id,d.department_name,e.salary,jg.grade_level from employees e,departments d,job_grades jg where e.department_id=d.department_id and e.salary between jg.minsalary and jg.maxsalary;

USERS(id,name,birth)

insert into users(id,birth) values(1,to_date('1998-01-01','fmyyyy-mm-dd'));
insert into users values(1,'abc',to_date('1998-01-01','fmyyyy-mm-dd'));

delete users where last_name='zhangsan';



SQL:结构化查询语言,select
DML:数据操纵语言:insert update delete
DCL:数据控制语言:commit rollback。
事务:一组SQL语句的单元(DML语句为主)
DDL:数据定义语言:create table users()


insert into student values(3,'cc',100.99,null);

DDL:数据定义语言
order by
blueuser
blueorder
blue_user
blue_order
oa_user

create table users(
  id number(10),
  name varchar2(40),
  age number(3)
);

alter table users add constaint users_pk primary key (id);

alter table users disable constraint users_pk;
alter table users enable constraint users_pk;

alter table users drop constraint users_pk;


alter table users set unused (name,age);

alter table users et unused column name;
alter table users set unused column age;

alter table users drop unused columns;

drop table users;

rename users to oa_users;

truncate table users;



select e.last_name,e.salary,e.department_id,d.mm from employees e,(select department_id dept_id,max(salary) mm from employees group by department_id) d where e.department_id=d.dept_id;


select dfdfd from A a left outer join (select dfa)

create or relpace view salary_vu
is
select e.last_name,d.department_name,e.salary,j.name from employees e,departments d,job_grades j where e.department_id=d.department_id and e.salary between j.minsalary and j.maxsalary;


 SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME ) A WHERE ROWNUM <= to ) WHERE RN >= from

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
14 4
|
11天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
51 2
|
9天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
46 0
|
10天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
41 0
|
28天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
106 6
|
26天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
58 3
Mysql(4)—数据库索引
|
28天前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
64 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
14天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
61 4
|
20天前
|
存储 关系型数据库 MySQL
如何在MySQL中创建数据库?
【10月更文挑战第16天】如何在MySQL中创建数据库?
|
24天前
|
SQL Oracle 关系型数据库
安装最新 MySQL 8.0 数据库(教学用)
安装最新 MySQL 8.0 数据库(教学用)
98 4

推荐镜像

更多
下一篇
无影云桌面