数据库(mysql oracle)学习小结

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
29天前
|
SQL 存储 关系型数据库
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
本文详细介绍了MySQL中的SQL语法,包括数据定义(DDL)、数据操作(DML)、数据查询(DQL)和数据控制(DCL)四个主要部分。内容涵盖了创建、修改和删除数据库、表以及表字段的操作,以及通过图形化工具DataGrip进行数据库管理和查询。此外,还讲解了数据的增、删、改、查操作,以及查询语句的条件、聚合函数、分组、排序和分页等知识点。
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
|
4天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
51 0
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
60 3
|
1月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
78 3
|
1月前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
92 2
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
270 15
|
1月前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
121 11
|
1月前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
1月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
1月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。

推荐镜像

更多