Oracle和Mysql数据库

数据库

  • Oracle 体系结构与基本概念
    • 体系结构
    • 基本概念
      • 表空间(users)和数据文件
      • 段、区、块
      • Oracle数据库的基本元素
  • Oracle数据库启动和关闭
    • Oracle数据库启动
    • Oracle数据库关闭
  • Sqlplus
    • sqlplus 登录数据库管理系统
      • 使用sqlplus登录Oracle数据库
      • 远程登录
      • 解锁用户
      • 修改用户密码
      • 查看当前语言环境
    • sqlplus基本操作
      • 显示当前用户
      • 查看当前用户下的表
      • 查看员工表的结构
      • 设置行宽
      • 设置页大小
      • 永久设置行宽、页宽
      • 设置员工ename的列宽
      • 设置薪水的列宽
    • Oracle默认方案
      • scott方案
        • 业务场景
        • 根据公司业务抽离出的表
      • hr方案
  • SQL
    • SQL语言的类型
      • DML
      • DDL
      • DCL
    • 基本 SELECT 语句
      • 查询案例
        • 查询员工号、姓名、薪水
        • 别名:as
        • DISTINCT关键字
        • 算数运算 + - * / 和 NULL值
      • 过滤和排序数据
        • where条件过滤
          • 查询10号部门的员工信息
          • 查询"KING"的信息
          • 修改系统当前日期格式
          • 比较运算
          • like:模糊查询
          • 逻辑运算
        • order by 排序
          • 使用 ORDER BY 子句排序
      • 单行函数
        • 字符函数
        • 数值函数
        • 时间函数
        • 日期函数
        • 转换函数
        • 通用函数
        • 条件表达式
      • 分组函数
        • having
      • 多表查询
        • 笛卡尔积
        • 等值连接
        • 不等值连接
        • 外连接
        • 内连接

Oracle 体系结构与基本概念

体系结构

Oracle服务器 :是一个数据管理系统(RDBMS),它提供开放的、 全面的、近乎完整的信息管理。由1个数据库和一个(或多个)实例组成。数据库位于硬盘上,实例位于内存中。
在这里插入图片描述

基本概念

表空间(users)和数据文件

1:n(表空间:数据文件)
逻辑概念:表空间由多个数据文件组成。位于实例上,在内存中。
物理概念:数据文件,位于硬盘之上。(C:\app\Administrator\oradata\orcl目录内后缀为.DBF的文件)
一个表空间可以包含一个或者是多个数据文件。
/home/oracle/app/oradata/orcl

段、区、块

在这里插入图片描述
段存在于表空间中;段是区的集合;区是数据块的集合;数据块会被映射到磁盘块。
在这里插入图片描述
在这里插入图片描述

Oracle数据库的基本元素

  • 方案schema
    方案就是一个集合,包含多个表(tables)、视图(views)、序列(sequences)、存储过程(store procudures)、索引(indexes)、同义词(synonyms)。
    oracle中每个用户都对应一个方案,方案名就是用户名。
  • 表table
    表示存储数据的逻辑容器,类似excel多行多列的表格。表创建的时候要定义它的每一列的列名以及该列的数据类型。(如:name char(10),表示定义列名为name类型为字符串型)
    创建表之后才可以往里边添加数据。
  • 视图view
    从多张表或者其他视图提取出用户所关心数据的一张虚表
  • 存储过程
    一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译。
  • 序列sequence
    是oracle提供的用于产生一系列唯一数字的数据库对象。
  • 索引index
    用于加快数据的检索,类似于书籍的索引。
  • 同义词synonyms
    别名的意思,和视图的功能类似。就是一种映射关系。

Oracle数据库启动和关闭

前提条件: 使用Oracle用户登录Linux操作系统
[root@localhost ~]# su - oracle
在这里插入图片描述
数据库管理员用户:
用户名:sys
密 码:sys

Oracle数据库启动

第一步: 通过数据库管理员登录Oracle数据库
[oracle@localhost ~]$ sqlplus / as sysdba;
在这里插入图片描述

第二步: 启动Oracle数据库
SQL> startup
在这里插入图片描述
第三步: 启动监听服务

SQL> quit
[oracle@localhost ~]$ lsnrctl start
在这里插入图片描述

Oracle数据库关闭

第一步: 通过数据库管理员登录Oracle数据库
[oracle@localhost ~]$ sqlplus / as sysdba;
在这里插入图片描述
第二步: 关闭Oracle数据库

SQL> shutdown immediate
在这里插入图片描述

第三步: 关闭监听服务
SQL> quit
[oracle@localhost ~]$ lsnrctl stop
在这里插入图片描述

Sqlplus

Oracle的sqlplus是与oracle数据库进行交互的客户端工具,借助sqlplus可以查看、修改数据库记录。在sqlplus中,可以运行sqlplus命令与sql语句
Sqlplus命令是用来修改以及调整sqlplus工具的命令。
Sql语句是用来让服务器执行相关动作的命令。

sqlplus 登录数据库管理系统

前提条件是Oracle数据库必须启动。

使用sqlplus登录Oracle数据库

sqlplus 用户名/密码
[oracle@localhost ~]$ sqlplus scott/11
在这里插入图片描述

远程登录

sqlplus 用户名/密码@//ip/实例名 ↙
远程登录oracle服务器方式,如(sqlplus scott/11@//192.168.161.130/orcl)
在这里插入图片描述
在这里插入图片描述

解锁用户

[oracle@localhost ~]$ sqlplus / as sysdba;
SQL> alter user scott account unlock;

在这里插入图片描述

修改用户密码

[oracle@localhost ~]$ sqlplus / as sysdba;
SQL> alter user scott identified by 11;
在这里插入图片描述

查看当前语言环境

SQL> select userenv('language') from dual;
在这里插入图片描述

sqlplus基本操作

前提条件是使用scott用户登录
[oracle@localhost ~]$ sqlplus scott/11

显示当前用户

SQL> show user
在这里插入图片描述

查看当前用户下的表

SQL> select *from tab;
在这里插入图片描述

查看员工表的结构

SQL> desc dept;
在这里插入图片描述

设置行宽

默认显示不好看,因此需要设置行宽。
在这里插入图片描述SQL> set linesize 140;

在这里插入图片描述

设置页大小

SQL> set pagesize 100;
在这里插入图片描述

永久设置行宽、页宽

在这里插入图片描述

在这里插入图片描述
永久设置edit打开为gedit。
在这里插入图片描述

设置员工ename的列宽

在这里插入图片描述

SQL> col ename for a6 (a表示字符串)
在这里插入图片描述

设置薪水的列宽

col sal for 9999(一个9表示一位数字)
在这里插入图片描述

Oracle默认方案

安装oracle数据库默认会自动创建scott和hr两个用户以及其方案,这些都是oracle提供给我们学习和练习的数据,我们直接在上边练习就好。

scott方案

业务场景

Scott(斯科特)是一家软件公司的数据分析师,公司为其提供专门的数据库管理账号以及方案。
公司有总裁一名(president)、经理(manager)、店员(clerk)、销售专员(salesman),分析师(analyst)若干。
公司设置有多个部门:会计部(accounting)、研发部(researching)、销售部(sales)。

根据公司业务抽离出的表
  • 员工信息表EMP(Employee)
  • 部门表DEPT(Department)
  • 工资等级表(SALGRADE)
  • 奖金表(BONUS)

在这里插入图片描述

grade: 薪水等级
losal: 最低薪水
hisal: 最高薪水
在这里插入图片描述

deptno: 部门编号
dname: 部门名称
loc: 部门位置

在这里插入图片描述
empno: 员工编号
ename: 员工姓名
job: 员工工种
mgr: 员工上司
hiredate: 雇佣日期
sal: 员工薪水
comm: 员工奖金
deptno: 员工部门编号
在这里插入图片描述

hr方案

0

在这里插入图片描述

SQL

结构化查询语言(Structured Query Language)简称SQL,是对数据库进行增、删、查、改等操作的语言。
SQL 是1986年10 月由美国国家标准局(ANSI)通过的数据库语言美国标准,接着,国际标准化组织(ISO)颁布了SQL正式国际标准。1989年4月,ISO提出了具有完整性特征的SQL89标准,1992年11月又公布了SQL92标准.
各种不同的数据库对SQL语言的支持与标准存在着细微的不同,这是因为,有的产品的开发先于标准的公布,另外,各产品开发商为了达到特殊的性能或新的特性,需要对标准进行扩展。

SQL语言的类型

DML

数据库中,称呼增删改查,为DML语句。(Data Manipulation Language 数据操纵语言),如:
增 insert
删 delete
改 update
查 select

DDL

数据定义语言(Data Definition Language)。如:
create table(创建表)
alter table(修改表)
truncate table(清空表)
drop table(删除表)
create view(视图)
create index(索引)
create sequence(序列)
create synonym(同义词)

DCL

数据控制语言(Data Control Language)。如:
commit(提交)
rollback(回滚)

基本 SELECT 语句

基本语法格式为:
在这里插入图片描述
语法描述说明:
花括号{}括起的部分为必填部分。
中括号[]括起来的部分为可选部分。
多种形式的语法用竖线|来表示并列单选,或者的意思。

SQL语句使用注意事项:

  • SQL 语言大小写不敏感。
  • SQL 可以写在一行或者多行,以分号;作为一条sql语句的结束标志。
  • 关键字不能被缩写也不能分行。
  • 各子句一般要分行写。
  • 使用缩进提高语句的可读性。

查询案例

查询员工号、姓名、薪水

在这里插入图片描述
增加查询年薪(使用表达式)

在这里插入图片描述

别名:as

在这里插入图片描述
解决乱码问题,修改系统字符集。
在这里插入图片描述
解决方法

DISTINCT关键字

去除结果集重复的行。
在这里插入图片描述

算数运算 + - * / 和 NULL值
  • 乘除的优先级高于加减
  • 优先级相同时,按照从左至右运算
  • 可以使用括号改变优先级

查询: 员工号、姓名、月薪、年薪、奖金、年收入。
在这里插入图片描述
结果不正确。没有奖金的员工,年收入不正确。
NULL值问题:
包含NULL值的表达式都为空。
NULL != NULL
任何算数运算碰到NULL值都变成NULL,任何逻辑运算碰到NULL值都变成假

解决:滤空函数:nvl(a, b) 如果a为NULL, 函数返回b。所以:sal * 12 + nvl(comm, 0) 年收入。
在这里插入图片描述
NULL != NULL举例:
在这里插入图片描述
在SQL中,判断一值是否等于另外一值不用“=” 和“!=”而使用is和is not。
在这里插入图片描述

过滤和排序数据

where条件过滤
查询10号部门的员工信息

在这里插入图片描述

查询"KING"的信息

在这里插入图片描述

修改系统当前日期格式

查询入职日期为1981年11月17日的员工:
在这里插入图片描述
查看系统当前的日期格式:
在这里插入图片描述
获取系统当前日期格式:

SQL> select * from v$nls_parameters在这里插入图片描述
修改日期格式:

SQL> alter session set NLS_DATE_FORMAT = 'yyyy-mm-dd '

在这里插入图片描述
再次查询:
在这里插入图片描述
改回系统默认格式:SQL> alter session set NLS_DATE_FORMAT = ‘DD-MON-RR’;

比较运算

普通比较运算符:

= 等于(不是==)> 大于
>= 大于等于< 小于
<= 小于等于<> 不等于(也可以是!=)

查询薪水不等于1250的员工信息:
在这里插入图片描述
查询工资在1000-2000之间的员工:
在这里插入图片描述
在这里插入图片描述
查询81年2月至82年2月入职的员工信息:
在这里插入图片描述

IN:在集合中。(not in 不在集合中)

在这里插入图片描述
查询部门号为10或20的员工信息:
在这里插入图片描述

在这里插入图片描述

like:模糊查询

‘%’匹配任意多个字符。
‘_’匹配一个字符。
查询名字以S开头的员工:
在这里插入图片描述

查询名字是4个字的员工:
在这里插入图片描述
转义字符:

增加测试例子:向表中插入员工:
SQL> insert into emp(empno, ename, sal, deptno) values(1001, ’ TOM_ABC ', 3000, 10)

查询名字中包含_的员工:

SQL> select * from emp where ename like '%\_% ' escape '\';
在这里插入图片描述
转义单引号本身:

SQL> select 'hello '' world' from dual;

使用两个单引号来完成转义。

在这里插入图片描述

逻辑运算

AND 逻辑与
OR 逻辑或
NOT 逻辑非

如果
……where 表达式1 and 表达式2;
……where 表达式2 and 表达式1;
这两句SQL语句功能一样吗?效率一样吗?
SQL在解析where的时候,是从右至左解析的。
所以and时应该将易假的值放在右侧,or时应该将易真的值放在右侧。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

order by 排序

order by + 列名,表达式,别名,序号。 注意:语法要求order by 子句应放在select的结尾。

使用 ORDER BY 子句排序

• ASC(ascend): 升序。默认采用升序方式。
• DESC(descend): 降序

查询员工信息,按月薪排序:
在这里插入图片描述

order by后有多列时,列名之间用逗号隔分,order by会同时作用于多列。
在这里插入图片描述
在这里插入图片描述

desc 只作用于最近的一列,两列都要降序排,则需要两个desc。即:
在这里插入图片描述
order by + 列名,表达式,别名,序号。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
查询员工信息, 按奖金由高到低排序:
在这里插入图片描述

结果前面的值为NULL, 数据在后面,如果是一个100页的报表,这样显示肯定不正确。较为人性化的显示应该将空值放在最后, 即:
在这里插入图片描述

排序的规则

  • 可以按照select语句中的列名排序
  • 可以按照别名列名排序
  • 可以按照select语句中的列名的顺序值排序
  • 如果要按照多列进行排序,则规则是先按照第一列排序,如果相同,则按照第二列排序;以此类推

单行函数

单行函数:只对一行数据进行计算,产生一个结果。函数可以没有参数,但必须要有返回值。如:concat、nvl

  • 操作数据对象 hello world
  • 接受参数返回一个结果
  • 只对一行进行变换
  • 每行返回一个结果
  • 可以转换数据类型
  • 可以嵌套
  • 参数可以是一列或一个值
字符函数

操作对象是字符串。
大致可分为两大类:一类是大小写控制函数,主要有
lower 转小写
在这里插入图片描述

upper 转大写
在这里插入图片描述

initcap 首字母大写
在这里插入图片描述

另一类是字符控制函数:有CONCAT、SUBSTR、LENGTH/LENGTHB、INSTR、LPAD | RPAD、TRIM、REPLACE

concat(a,b):连接字符串a和b,只能连接两个

在这里插入图片描述

注意:SQL双引号“”表示别名,使用‘’来表示字符串。

另一种连接字符串的方法,使用||,可以做到多个字符串连接
在这里插入图片描述
在这里插入图片描述

substr(a, b):从a中,第b位开始取(计数从1开始),取到结尾。
在这里插入图片描述

substr(a, b, c):从a中,第b位开始,向右取c位。
在这里插入图片描述

length:字符数, lengthb:字节数
在这里插入图片描述

instr:在母串中查找子串, 找到返回下标,计数从1开始。没有返回0
在这里插入图片描述

lpad:左填充,参1:待填充的字符串,参2:填充后字符串的总长度(字节), 参3:填充什么
rpad:右填充。
在这里插入图片描述

trim:去掉前后指定的字符
在这里插入图片描述
在这里插入图片描述

replace:替换
在这里插入图片描述
在这里插入图片描述

数值函数

ROUND: 四舍五入
在这里插入图片描述

TRUNC: 截断
在这里插入图片描述

MOD: 求余

在这里插入图片描述

时间函数

在Oracle中日期型的数据,既有日期部分,也有时间部分。下一节介绍日期部分。
在这里插入图片描述
显示 昨天、今天、明天:
在这里插入图片描述
计算员工的工龄:
在这里插入图片描述

日期函数

上面求取员工工龄的结果不精确,如果想将其算准确,可以使用日期函数来做。

months_between:两个日期值相差的月数(精确值) 跟between…and无关
在这里插入图片描述

add_months:在某个日期值上,加上多少的月,正数向后计算,负数向前计算。
在这里插入图片描述

last_day:日期所在月的最后一天。
在这里插入图片描述

next_day:指定日期的下一个日期

在这里插入图片描述
在这里插入图片描述

转换函数

在不同的数据类型之间完成转换。将“123” 转换为 123。有隐式转换和显式转换之分。

隐式转换:
在这里插入图片描述

显式转换:
在这里插入图片描述

隐式转换的前提条件是:被转换的对象是可以转换的。

在这里插入图片描述
显示转换:借助to_char(数据,格式)、to_number、to_date函数来完成转换。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
如果隐式转换和显示转换都可以使用,应该首选哪个呢?

SQL优化:如果隐式、显式都可以使用,应该首选显式,这样可以省去Oracle的解析过程。

在固定的格式里加入自定义的格式,是可以的,必须要加“”。
在这里插入图片描述
反向操作:已知字符串“2024-2-1 18:30:20 ”转化成日期。
在这里插入图片描述
在这里插入图片描述

查询员工的薪水:2位小数, 本地货币代码, 千位符
在这里插入图片描述
将$2,975.00转化成数字:
在这里插入图片描述

通用函数

这些函数适用于任何数据类型,同时也适用于空值:

  • NVL (expr1, expr2)
    在这里插入图片描述

  • NVL2 (expr1, expr2, expr3)

  • NULLIF (expr1, expr2)

  • COALESCE (expr1, expr2, …, exprn)

nvl2: 是nvl函数的增强版。 nvl2(a, b, c) 当a = null 返回 c, 否则返回b。
在这里插入图片描述

nullif: nullif(a, b) 当 a = b 时返回null, 不相等的时候返回a值。
在这里插入图片描述

coalesce: coalesce(a, b, c, …, n) 从左向右找参数中第一个不为空的值。
在这里插入图片描述

条件表达式

分组函数

having

多表查询

笛卡尔积
等值连接
不等值连接
外连接
内连接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/447750.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【算法分析与设计】交换两个节点

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;算法分析与设计 ⛺️稳中求进&#xff0c;晒太阳 题目 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本…

【C++】 C++入门— 基于范围的 for 循环

C 基于范围的for循环1 使用样例2 使用条件3 完善措施 Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢阅读&#xff01;下一篇文章见&#xff01;&#xff01;&#xff01; 基于范围的for循环 1 使用样例 使用for循环遍历数组&#xff0c;我们通常这么写&#xff1a; …

八、硬盘(disk)

永久存储性设备&#xff1a;电脑硬盘、移动硬盘、U盘、机身内存… 世界第一块硬盘叫做350RAMAC&#xff0c;是1956年诞生的&#xff0c;IBM公司生产的&#xff0c;比冰箱大&#xff0c;1吨重&#xff0c;只有5MB的容量 1、机械硬盘(HDD) 机械硬盘(Hard Disk Drive&#xff0c;简…

数学建模比赛中,chatgpt、文心一言如何提问更有效?

在数学建模的战场上&#xff0c;ChatGPT和文心一言可是我们的“神助攻”&#xff01;但想让它们发挥出最大威力&#xff0c;提问可是个技术活。问题问得好&#xff0c;答案跑不了&#xff1b;问题问得妙&#xff0c;解决没烦恼&#xff01; 下面我就一个实际的对话为例&#x…

ele-h5项目使用vue3+vite开发:第二节、search 搜索框组件开发

如何设计一个组件 需求分析 布局 content left-iconbodyinput-controlright-iconaction 功能 使用 defineEmits 定义组件的事件 在组件的script setup 里如何定义事件 使用defineEmits&#xff08;&#xff09;定义先声明事件接口 <script setup lang"ts"> int…

[python] 过年燃放烟花

目录 新年祝福语 一、作品展示 二、作品所用资源 三、代码与资源说明 四、代码库 五、完整代码 六、总结 新年祝福语 岁月总是悄然流转&#xff0c;让人感叹时间的飞逝&#xff0c;转眼间又快到了中国传统的新年&#xff08;龙年&#xff09;。 回首过去&#xf…

【C语言】好题分享(2)

目录 一&#xff1a;转移表 —— 计算器的一般实现 我们来分析 代码实现 二&#xff1a;字符串旋转 我们来分析 代码实现 结语 一&#xff1a;转移表 —— 计算器的一般实现 题目&#xff1a;使用函数指针数组的实现简单的加减乘除计算器 我们来分析 计算器要能够实现加…

猫用空气净化器好吗?好用的养猫宠物空气净化器品牌推荐

作为一个养猫五年的资深铲屎官&#xff0c;我对如何轻松快乐地养猫有一些心得。猫咪每天在家里奔跑&#xff0c;导致家里经常会出现“猫毛雪”&#xff0c;沙发、地板和衣服都成了重灾区。在除猫毛的问题上&#xff0c;我真的尝试了各种方法&#xff0c;几乎用上了所有的技能。…

nightinage部署

git开源地址 GitHub - ccfos/nightingale: An all-in-one observability solution which aims to combine the advantages of Prometheus and Grafana. It manages alert rules and visualizes metrics, logs, traces in a beautiful web UI. 一、下载源码自己编译运行 二、用…

【技术分享】远程透传网关-单网口快速实现各类串口PLC程序远程上下载

准备工作 一台可联网操作的电脑一台单网口的远程透传网关及博达远程透传配置工具网线一条&#xff0c;用于实现网络连接一台串口PLC及其编程软件一个9针串口头及连接线&#xff0c;用于连接PLC一张4G卡或WIFI天线实现通讯(使用4G联网则插入4G SIM卡&#xff0c;WIFI联网则将WI…

如何在Shopee平台上进行手机类目选品?

在Shopee平台上进行手机类目的选品是一个关键而复杂的任务。卖家需要经过一系列的策略和步骤&#xff0c;以确保选品的成功和销售业绩的提升。下面将介绍一些有效的策略&#xff0c;帮助卖家在Shopee平台上进行手机类目选品。 先给大家推荐一款shopee知虾数据运营工具知虾免费…

C++新特性 协程

本篇文章我们来讲述一下C协程 协程&#xff08;Coroutine&#xff09;是一种能够挂起个恢复的函数过程 是一种轻量级的并发编程方式&#xff0c;也称为用户级线程。它与传统的线程&#xff08;Thread&#xff09;相比&#xff0c;具有更低的开销和更高的执行效率。 协程通常运…