Oracal学习

Oracle是什么

是甲骨文公司的一款支持事务且吞吐量高的数据库特点:
(1)支持多用户、大事务量的事务处理
(2)数据安全性和完整性控制
(3)支持分布式数据处理
(4)可移植性

Oracal数据类型及语句

Oracal数据类型

1.字符型

1.1CHAR:固定长度的字符类型,最多存储2000个字节
1.2VARVCHAR2:可变长度的字符类型,最多4000个字节
1.3LONG:打文本类型,最大可存储2个G

2.数值型

NUMBER:数值类型
例如:NUMBER(5) 最大可以存的数为99999
NUMBER(5,2) 最大可以存的数为999.99–(5为总位数)

3.日期型

3.1DATE:日期时间型,精确到秒
3.2TIMESTAMP:精确到秒的小数点后9位

4.二进制(大数据类型)

4.1CLOB:存储字符,最大4G
4.2BLOB:存储图像、声音、视频等二进制数据,最多4个G

Oracal语句(语句基本=MYSQL)

建表

CREATE TABLE 表名 (列名1 数据类型(长度) [约束条件],列名2 数据类型(长度) [约束条件],...列名n 数据类型(长度) [约束条件],PRIMARY KEY (主键列名),FOREIGN KEY (外键列名) REFERENCES 外部表名(外部键列名),UNIQUE (唯一索引列名),CHECK (列名 BETWEEN 值1 AND 值2), -- 或其他检查条件INDEX 索引名 ON (列名)
);-- 示例:
CREATE TABLE Employees (EmployeeID NUMBER(6) PRIMARY KEY,FirstName VARCHAR2(50),LastName VARCHAR2(50),HireDate DATE NOT NULL,Salary NUMBER(8, 2) CHECK (Salary > 0),DepartmentID NUMBER(3),CONSTRAINT FK_Department FOREIGN KEY (DepartmentID) REFERENCES Departments(DepartmentID)
);
NUMBER(p, s):指定数字类型的精度(p)和小数位数(s),如NUMBER(6)表示整数,NUMBER(8, 2)表示最多有两位小数的数值。
VARCHAR2(length):变长字符串类型,最大长度由括号内的数字决定。
DATE:日期时间类型。
PRIMARY KEY:定义主键约束,确保字段值唯一且非空。
FOREIGN KEY:定义外键约束,关联到另一个表的主键。
CHECK:定义检查约束,限制列值满足特定条件。
UNIQUE:定义唯一性约束,保证该列所有行的值都是唯一的。
INDEX:创建一个索引,提高查询性能。不过,在创建表时直接定义索引并不常见,通常在建表后单独创建。

复制表

-- 完全复制表结构及数据
CREATE TABLE new_table_name AS
SELECT * FROM old_table_name;-- 只复制表结构(不包含数据)
CREATE TABLE new_table_name AS
SELECT * FROM old_table_name
WHERE 1 = 2; -- 这里添加一个永远不满足的条件,确保不会复制任何数据-- 复制部分列并复制数据
CREATE TABLE new_table_name AS
SELECT column1, column2, column3 FROM old_table_name;

删除表

方式一:drop table 表名;
方式二:truncate table 表名;

在Oracle 中 ,双引号主要是别名的时候使用, 单引号是使用的值, 是字符

oracle函数

oracle的空值处理(类似于mysql的ifnull)

nvl(参数1,参数2):如果1为null,则返回2,不为null就为1nvl2(参数1, 参数2, 参数3)1为null,则返回,3,不为null,则返回2decode(需要判断的字段,
​ 常量值1, 结果值1,
​ 常量值2, 结果值2,
​ …
​ 常量值n, 结果值n,
​ 默认结果值
​ )select e.ename 姓名,e.sal 底薪,e.comm 奖金,nvl(e.sal+e.comm, e.sal) 实发1,nvl2(e.comm, e.sal+e.comm, e.sal) 实发2,decode(e.comm, null, e.sal, e.sal+e.comm) 实发3
from emp e;

nvl(mysql的ifnull)

nvl(参数1,参数2):如果1为null,则返回2,不为null就为1

nvl2(mysql的if)

nvl2(参数1, 参数2, 参数3)1为null,则返回,3,不为null,则返回2

decode(没合适的试下这个)

···Oracle的DECODE函数是一个条件表达式函数,它在SQL查询中用于基于某个字段或表达式的值返回不同的结果。下面通过几个例子来说明如何使用DECODE函数:

示例1:简单条件判断

假设我们有一个员工表EMPLOYEES,其中包含一个字段SALARY_GRADE表示工资等级(例如,0代表初级,1代表中级,2代表高级),我们想在查询结果中显示对应的等级名称而不是数字。

SELECT employee_name,DECODE(salary_grade, 0, '初级', 1, '中级', 2, '高级') AS salary_level
FROM EMPLOYEES;

在这个例子中,DECODE(salary_grade, 0, '初级', 1, '中级', 2, '高级')的工作原理是:

  • 如果 salary_grade 的值等于0,则返回字符串 '初级';
  • 如果 salary_grade 的值等于1,则返回 '中级';
  • 如果 salary_grade 的值等于2,则返回 '高级';
  • 若 salary_grade 不等于上述任何一个值,则默认返回 NULL(如果没有指定默认值)。
示例2:带有默认值的情况

如果我们还想为未列出的其他所有等级提供一个默认等级名称“未知”,可以这样写:

SELECT employee_name,DECODE(salary_grade, 0, '初级', 1, '中级', 2, '高级', '未知') AS salary_level
FROM EMPLOYEES;

在这里,最后的一个参数 '未知' 就是当 salary_grade 不匹配前面任何条件时返回的默认值。

示例3:嵌套使用

更复杂的场景下,可能需要多个条件和嵌套的DECODE函数,例如:

Sql
SELECT employee_name,DECODE(department_id,10, DECODE(job_title, 'Manager', '部门经理', 'Employee'),20, DECODE(job_title, 'Engineer', '工程师'),'未知职位') AS position
FROM EMPLOYEES;

这个例子中,首先根据 department_id 进行判断:

  • 如果 department_id 是10,并且 job_title 是 'Manager',则返回 '部门经理';
  • 否则,如果 department_id 是10且 job_title 不是 'Manager',则返回 'Employee';
  • 如果 department_id 是20并且 job_title 是 'Engineer',则返回 '工程师';
  • 对于所有其他情况,返回 '未知职位'。

示例4:达到nvl2效果的写法
decode ((SELECT 1FROM CM_MATERIAL bWHERE a.site_code = b.site_codeAND b.CUSTOM_ATTRIBUTE = 'CELL'AND f.PART_MATERIAL_CODE = b.material_code), null,'','BatteryCell') as temp如果SELECT 1...这坨返回null,则temp显示为 ''这坨返回不为null,则temp显示为 BatteryCell

字符串拼接 ||

1. Oracle 特有的连接符: || 拼接

select 'SN:' ||  ppk.SN_CODE "字符串拼接后别名"
from PP_KEY_PART_BYTE ppk

2. concat(str1,str2) 函数, 在mysql和Oracle中都有

select concat('SN:',ppk.SN_CODE) "函数拼接字符串后别名"
from PP_KEY_PART_BYTE ppk;

在Oracle SQL中,ESCAPE 关键字通常与 LIKE 或 REGEXP_LIKE 这样的字符串匹配函数一起使用,用于指定通配符的转义字符。当你的搜索模式中包含特殊字符(如 %、_ 等)并且你想让这些字符按照字面意义进行匹配时,就需要使用转义字符。示例1:LIKE 语句中的 ESCAPE假设我们有一个名为 PRODUCTS 的表,其中有一个 DESCRIPTION 字段,现在要查找描述中包含 % 字符的产品:Sql
SELECT * FROM PRODUCTS
WHERE DESCRIPTION LIKE '%\%%' ESCAPE '\';
在这个例子中,ESCAPE '\' 指定了反斜杠 \ 作为转义字符。因此,'\%' 在查询中表示的是一个字面上的 % 而不是一个通配符。这个查询将返回所有描述字段中包含 % 字符的产品记录。

排序时控制null的显示位置

···在Oracle SQL中,当进行排序时,默认情况下NULL值的处理可能因数据库版本和排序方式(升序或降序)而有所不同。但你可以通过NULLS FIRST 或 NULLS LAST 来明确指定NULL值在排序结果中的位置。

例如,在一个名为 EMPLOYEES 的表中,假设有一个字段 BONUS 可能包含NULL值,我们想要按照 BONUS 进行排序,并控制NULL值的位置:

  1. 将NULL值放在最后(默认在某些情况下的升序排序行为):
Sql
1SELECT *
2FROM EMPLOYEES
3ORDER BY BONUS ASC NULLS LAST;
  1. 将NULL值放在最前(对于降序排序,这是默认行为;对于升序排序,需要明确指定):
Sql
1SELECT *
2FROM EMPLOYEES
3ORDER BY BONUS DESC; -- 在降序排序下,NULL值默认显示在前面
4
5-- 如果你希望在升序排序时NULL值也显示在前面,则这样写:
6SELECT *
7FROM EMPLOYEES
8ORDER BY BONUS ASC NULLS FIRST;

给数据排名(dense_rank,rank)

dense_rank(并列不累加排名)

如果有多个第一名,则他们都是第一名

第二名显示的排名仍然是2

rank(并列累加排名)

row_number(不并列排名)

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

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

相关文章

【C++】C++入门基础讲解(一)

💗个人主页💗 ⭐个人专栏——C学习⭐ 💫点击关注🤩一起学习C语言💯💫 导读 经过一段时间的C语言学习,我们以及基本掌握了C语言的知识,今天,我们就开始学习C,…

2024最新幻兽帕鲁服务器多少钱一个?

幻兽帕鲁服务器多少钱?价格便宜,阿里云4核16G幻兽帕鲁专属服务器32元1个月、66元3个月,4核32G配置113元1个月、339元3个月;腾讯云4核16G14M服务器66元1个月、277元3个月、1584元一年。阿腾云atengyun.com分享阿里云和腾讯云palwor…

SpringBoot的自动装配原理

一、SpringBootConfiguration注解的作用 SpringBootApplication注解是SpringBoot项目的核心注解,加在启动引导类上。点击进去可以发现SpringBootApplication注解是一个组合注解。其中SpringBootConfiguration和EnableAutoConfiguration是由Spring提供的,剩下的注解是由JDK提供的…

简单计算与模拟1:鸡兔同笼(POJ 3237)

1 问题描述 图1 问题描述 2 解题思路 鸡有两只脚&#xff0c;兔子有四只脚&#xff0c;且输入数据可能为奇数&#xff0c;使用公式计算即可。 3 设计代码 #include <cstdio> int main() {int nCases, nFeets;while (scanf("%d", &nCases) ! EOF){for (in…

负载均衡-Ribbon-自定义负载均衡算法

1.Ribbon 是什么 SpringCloud Ribbon 是基于 Netflix Ribbon 实现的一套客户端负载均衡的工具主要功能是提供客户端的软件负载均衡算法&#xff0c;将 Netflix 的中间服务处连接在一起Ribbon的客户端组件提供一系列完整的配置项&#xff0c;如&#xff1a;连接超时、重试等。简…

echarts 绘制垂直滚动热力图

问题1&#xff1a;提示功能无效 问题2&#xff1a;值筛选无效 效果 在线浏览 下载echarts官网例子(heatmap Examples - Apache ECharts) 稍作改动&#xff1a; generateData 入参改为长度和宽度noise.perlin2(i / 40, j / 20) Math.random() * 5y轴倒置指定zlevel为2 通过定…

蓝桥杯备战——7.DS18B20温度传感器

1.分析原理图 通过上图我们可以看到DS18B20通过单总线接到了单片机的P14上。 2.查阅DS18B20使用手册 比赛的时候是会提供DS18B20单总线通讯协议的代码&#xff0c;但是没有提供读取温度数据的代码&#xff0c;所以还是需要我们去查看手册&#xff0c;我只把重要部分截下来了 …

python-自动篇-运维-根据计算机硬盘、主板、CPU生成注册信息

文章目录 准备代码效果 准备 本实例需要使用WMI模块&#xff0c;所以需要安装WMI模块。在安装WMI模块之前&#xff0c;先要安装pywin32模块&#xff0c;WMI模块需要win32api的支持。使用pip安装pywin32模块和WMI模块的代码如下&#xff1a; pip install win32com pip install …

Ubuntu 22.04 安装tomcat

tomcat是常用的Java服务容器,这篇文章我们就来讲讲如何安装它。 更新软件包 首先是更新软件包,这是最常规的操作 sudo apt update 然后是开始安装,不多一会就可以安装好了 sudo apt install tomcat9 然后看一下状态 sudo systemctl status tomcat9 发现虽然启动了,但…

Python第十一章(推导式)

一。列表推导式&#xff1a;目的化简代码&#xff0c;可以改变数据 例句1&#xff1a;如果while循环继续创建序列累加 例句2&#xff1a;如果for循环进行列表累加 1.循环列表推导式进行累加&#xff1a; 注释&#xff1a;第一个i表示的是返回的数据于列表&#xff0c;for后面内…

windows上使用anconda安装tensorrt环境

windows上使用anconda安装tensorrt环境 1 安装tensorrt1.1 下载最新的稳定的tensorrt 8.6.1(tensorrt对应的cuda、cudnn等版本是参考链接4)1.2 将tensorrt添加到环境变量1.3 安装tensorrt依赖1.4 安装Pycuda1.5 安装pytorch 2 测试2.1 测试TensorRT 样例(这个测试主要来源于参考…

【Python】01快速上手爬虫案例一:搞定豆瓣读书

文章目录 前言一、VSCodePython环境搭建二、爬虫案例一1、爬取第一页数据2、爬取所有页数据3、格式化html数据4、导出excel文件 前言 实战是最好的老师&#xff0c;直接案例操作&#xff0c;快速上手。 案例一&#xff0c;爬取数据&#xff0c;最终效果图&#xff1a; 一、VS…

docker生命周期管理命令

文章目录 前言1、docker create2、docker run2.1、常用选项2.2、系统2.3、网络2.4、健康检查 3、docker start/stop/restart4、docker kill5、docker rm6、docker pause/unpause总结 前言 在云原生时代&#xff0c;Docker已成为必不可少的容器管理工具。通过掌握Docker常用的容…

uniCloud发行部署H5进行网页托管

生成文件&#xff0c;生成文件这个和我们平时用uniapp 生成H5的时候是一样的&#xff0c;我们可以选择hash 或者history 模式&#xff0c;默认的这是显示的根目录&#xff0c;如果我们在根目录下建立了H5目录&#xff0c;那么我们在发布H5的时候&#xff0c;是需要在manifest.j…

数据恢复与硬盘修理

目录 第1章 基础知识 1.1 数据恢复技术的发展和研究现状 1.2 数据恢复技术的层次与体系 1&#xff0e;网络层 2&#xff0e;网络存储层 DAS NAS 3&#xff0e;磁盘阵列层 4&#xff0e;磁盘层 5&#xff0e;文件系统层 6&#xff0e;文件层 7&#xff0e;覆盖恢复…

越活越“老“越值钱——来喝了这碗孟婆汤吧

目录 一、背景介绍二、思路&方案三、过程1.开头先从小编的行业说起2.扩展到各行各业&#xff0c;从小编的视角和认知的对比3.纵观人类发展和科技发展的对比4.我身边就有越活越"老"越值钱的人5.如何做到这一点的基本逻辑 四、总结 一、背景介绍 对于自己的未来&a…

Java强训day4(选择题编程题)

选择题 接口中的方法是为了让重写编程题 题目 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int a_b sc.nextInt();int b_c sc.nextInt();int ab sc.nextInt();int bc sc.nextInt();for(in…

mysql索引失效

索引失效 1.违反最左前缀法则 查询要从索引的最左前列开始&#xff0c;不能跳过索引中的列 没有违反 违反 部分违反&#xff0c;只有最左边的命中索引 2.查询右边范围的列&#xff0c;不能使用索引 范维列不满足最左前缀 3.索引列上进行运算&#xff0c;索引会失效 改变…

假期刷题打卡--Day15

1、MT1152韩信又生气了 韩信点兵(大于10人)&#xff0c;三个三个一排少1个人&#xff0c;五个五个一排又少1个人&#xff0c;七个七个一排还少1个人。韩信生气了&#xff0c;从别的队伍里调来一个人!这样不管是三个一排五个一排还是七个一排都完美了。问原本最少应该有多少人。…

每日一练 | 华为认证真题练习Day172

1、关于OSPF的ASBR-SUMMARY-LSA中LSA头部他、信息描述错误的是 A. LINK STATE ID表示ASBR的ROUTER ID B. ADVERTISING ROUTER表示该ABR的ROUTER ID C. ADVERTISING ROUTER字段永远不会改变 D. METRIC表示该ABR到达ASBR的OSPF开销 2、关于OSPF外部路由种类描述错误的是 A. …