Oracle-day1:scott用户、查询、取整、截取、模糊查询、别名——23/8/23

整理一下第一天软件测试培训的知识点

1、scott用户

-- 以system管理员登录锁定scott用户
alter user scott account lock;-- 以system管理员登录解锁scott用户
alter user scott account unlock;-- 以system管理员用户设置scott用户密码
alter user scott identfied by tiger;

前提条件:

使用system管理员账号登录了,这时解锁了scott普通用户

在scott用户下,有emp员工信息表

-- 前提:在scott普通账号下,有一个emp表
-- emp 员工信息表-- empno 员工编号 number数字类型--ename 员工姓名 varchar2字符串类型--job 工作岗位 varchar2字符串类型--mgr 上级领导 number数字类型--hiredate 入职日期 date时间类型--sal 工资,number类型--comm 奖金,number类型--deptno 部门编号 number

后面的内容都基于scott的emp表进行操作

2、DQL操作 -- 查询

       DQL操作:对已有的表进行数据的查询和筛选
       select -- 选择、查询
       select * from 表名; scott用户可以省略
       *:通配符,表示所有列和列名同时存在时,应写为:表名.*

2.1、select 查询语句

-- 1、查询全部数据
-- 此时在管理员账号,查询scott账号下的emp表
select * from scott.emp;
-- 如果当前是scott,可以省略scott
-- select * from emp;-- 2、查询指定列的数据
-- select 列1,列2 from 表;
select empno,ename from scott.emp;-- 3、查询满足条件的值
-- 查询工资>3000的人
select empno,ename from scott.emp where sal >= 3000;select emp.*,sal from scott.emp where sal >= 3000;

2.2、对数字列进行计算

-- 4、对数字列进行运算
/*+-*/% -- 取余
*/
select emp.*,sal+200,sal-50,sal*1.3,sal/1.2 from scott.emp;
-- emp.*是查询到了emp表的所有列,然后后面就可以拼接其他列,一共查询到12列
-- 对列进行运算,会产生一个新的列
-- 每一列都是独立的!都是独立的重新从原有基础上进行运算,而不是从前一列再运算

2.3、向上ceil/下floor取整

/*取整:1、ceil() 向上取整2、floor() 向下取整
*/
-- 当小数不为零,ceil向上(往大的数走)取整
select emp.*,ceil(sal+200.5) from scott.emp;-- 当小数不为0,floor往下(往小的数走)取整
select emp.*,floor(sal+200.2) from scott.emp;-- 如果小数部分为0,ceil和floor直接取整数部分-- celi和floor并不是四舍五入,如果是-4.1,同时使用celi和floor
-- ceil(-4.1)取到的值是-4(向上取整,往大了取)
-- floor(-4.1)取到的值则是-5(向下取整,往小的取)

2.4、时间date

/*时间:date*/
-- sysdate 系统时间,返回值是 日期
-- current_date 当前时间,返回值是 日期
select sysdate,current_date from dual;

2.5、截取日期

-- 2、截取sal表中的日期:hiredate
/*a的值为时间列,n的值可以有以下:1、mm - 返回当月第一天2、yy - 返回当年第一天3、dd - 返回当前年月日4、yyyy - 返回当年第一天5、d - (星期天)返回当前星期的第一天6、hh - 当前时间7、mi - 没有秒的精准度
*/
select trunc(hiredate,'dd') from scott.emp;    
select trunc(hiredate,'yy') from scott.emp;

2.6、四舍五入

/*四舍五入、截取1、round(a,n) 四舍五入,n表示小数位,n省略则四舍五入到整数部分2、trunc() 用于截取时间和数字的函数3、trunc(a,n) 用于截取时间和数字的函数,n表示小数的位数,n省略表示截取到整数部分
*/
select * from scott.emp;
-- 1、运算 sal工资,乘1.2然后四舍五入
select round(sal * 1.2,2) from scott.emp;

2.7 列别名

/*取别名:1、给列取别名(列可以是已有的列,也可以是运算生成的列) 在低版本语法中需要加上asselect age 别名,name 别名注意:1、as可以省略2、列名不能重复3、别名建议不重复,别名可以用双引号进行包裹4、别名不要使用关键字       
*/
select * from scott.emp;
select ename "名字" from scott.emp; -- 给emp的ename取别名

2.8 表别名

/*对表取别名表取别名后,出现表名时候必须要使用别名,否则报错别名不能重复,表别名可以使用双引号
*/
select * from scott.emp a; -- 这是给表取了个别名a
select * from scott.emp "a+1"; -- 这种别名可以用双引号包括-- 给表的列取别名
select emp.*,sal/1.2 sal1,trunc(sal/1.2) sal2 from scott.emp;
-- 此时,如果给表取一个别名,这个时候在列的部分使用 emp就不对了
select e.*,sal/1.2 sal1,trunc(sal/1.2) sal2 from scott.emp e;
-- 这个时候emp就应该换成别名来代替了,如果不用别名,提示标识符错误
-- 例如这样
select e.ename from scott.emp e;

2.9 where查询

/*带where条件的查询:-- 可带有 > < = <= >=  (!+ <>)不等于-- 比较运算符两边的数据类型需要一致
*/
-- 精准查询
select * from scott.emp where deptno = 10; -- deptno 部门号
-- 数字类型是可以加上 单引号的
select * from scott.emp where deptno = '10';-- 范围筛选:> < >= <= 
select * from scott.emp where sal < '1000';

2.10 模糊查询

-- 模糊查询
-- -1、以 A开头的: A%
-- -2、以A结尾的:%A
-- -3、包含A:%A%
-- -4、
-- 语法:查询 where 条件列 like '模糊条件'
-- 找出以A开头的
select * from scott.emp where ename like 'A%';-- 找出以A结尾的
select * from scott.emp where ename like '%A';-- 找出包含A的
select * from scott.emp where ename like '%A%';

2.11 用函数来模糊查询

-- 在数据量大的情况下,link的弊端会体现出来
/*这个时候,就可以使用到函数substr()substr(str,begin,[num])在str中从begin位置开始连续截取num数量的字符可以正向和反向截取正向从1开始,反向从-1开始substr(str,begin)在str中从begin位置开始截取str字符串的末尾,如果没有就返回空值字符串的最后一位正向数是字符串的长度 反向数是-11、以A开头:substr(字符串,开始的位置,截取的长度) = 'Asubstr(字符串,1,1) = 'A'2、以A结尾substr('字符串',-1,1) = 'A'substr(字符串,-1) = 'A' 从末尾结尾时,后面的1可以省略
*/
-- 语句:查询以A开头
select * from scott.emp where substr(ename,1,1) = 'A';-- 语句:查询以A结尾
select * from scott.emp where substr(ename,-1,1) = 'A';
select * from scott.emp where substr(ename,-1) = 'A';/*也可以用字符串的长度函数来操作substr(字符串,-length(字符串),1) = 'A'substr(字符串,length(字符串),1) = 'A'substr(字符串,length(字符串)) = 'A'
*/
-- 1、以A开头
select * from scott.emp where substr(ename,-length(ename),1) = 'A';-- 2、以A结尾
select * from scott.emp where substr(ename,length(ename),1) = 'A';
select * from scott.emp where substr(ename,-length(ename)) = 'A';-- 如果在这里给列取了别名,那么在 查询条件中使用列别名,就会出错,因为
-- 别名是在查询结束以后才会产生,在查询期间是无效的--3、查询员工姓名第三位是A的
select * from scott.emp where ename like '__A%';
select ename,substr(ename,3,1) from scott.emp where substr(ename,3,1) = 'A';-- 4、查询第三位是A第五位是E的记录
select *  from scott.emp where ename like '__A_E%';select ename,substr(ename,3,1),substr(ename,5,1) from scott.emp 
where 
substr(ename,3,1) = 'A'
and
substr(ename,5,1) = 'E';

2.12 逻辑运算符

/*逻辑运算符:and:两个条件同时满足,并且or:两个条件满足其一,和not:不是-- 执行顺序:先not、再and,后or
*/

逻辑运算符练习

-- 1、查询10号部门和20号部门的员工信息
select * from scott.emp where deptno = 10 or deptno = 20;-- 2、查询10号部门中工资超过2000的员工信息(两个条件同时满足条件,并且)
select * from scott.emp where deptno = 10 and sal > 2000;-- 3、查询10号部门中工资超过2000的员工信息和20号部门且工资小于1000的(两个条件同时满足条件,并且)
select * from scott.emp where deptno = 10 and sal > 2000;
select * from scott.emp where deptno = 10 and sal > 2000 
or deptno = 20 and sal < 1000;-- 4、查询10号和20号两个部门中,工资都高于2000的员工信息(并且)
select * from scott.emp where (deptno = 10 or deptno = 20) and sal > 2000;-- 5、查询不是20号部门的员工
select * from scott.emp where deptno <> 20;
select * from scott.emp where deptno != 20;-- 6、找出工资大于800的员工 CLERK 和工资大于900的销售员 SALESMAN
select * from scott.emp where (job = 'CLERK' and sal > 800) or (job = 'SALESMAN' and sal > 800);

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

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

相关文章

libdrm全解析一 —— 总述

本文参考以下博文&#xff1a; Linux libdrm代码完全解析 LIBDRM使用 最简单的DRM应用程序 &#xff08;single-buffer&#xff09; Linux libdrm库入门教程 10. DRM图形显示框架 LIBDRM 特此致谢&#xff01; 一、介绍 BLFS中给出的介绍 libdrm提供了一个用户空间库&…

Sulfo-CY3 DBCO在生物传感和靶向标记方面的优势

​欢迎来到星戈瑞荧光stargraydye&#xff01;小编带您盘点&#xff1a; Sulfo-Cyanine3 DBCO在生物传感和靶向标记方面具有许多优势&#xff0c;使其成为生物医学研究中的工具。以下是Sulfo-Cyanine3 DBCO在生物传感和靶向标记方面的主要优势&#xff1a; **1. 特异性&#x…

PostgreSQL-研究学习-介绍与安装

PostgreSQL-预研 是个很厉害的数据库的样子 ψ(*&#xff40;ー)ψ 官方文档&#xff1a;http://www.postgres.cn/docs/12/ 总的结论和备注 PgSQL 支持对JSON的支持很强大&#xff0c;以及提供了很多数学几何相关的数据类型【例&#xff1a;点&#xff0c;线条&#xff0c;几何…

【面试题】:axios二次封装都进行了哪些配置以及如果项目里面有两个baseURL你怎么解决?

一.axios的概念 Axios 是一个基于 promise 网络请求库&#xff0c;作用于node.js 和浏览器中。 它是 isomorphic 的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生 node.js http 模块, 而在客户端 (浏览端) 则使用 XMLHttpRequests。 二.axios的特点&#xf…

动态调用python类和函数

遇到一个需求&#xff0c;需要尽可能的尝试触发python模块里的行为&#xff0c;比如函数&#xff0c;类实例这样&#xff0c;感觉和java里的反射有点像&#xff1b;通过调研发现python里有getattr这个方法&#xff0c;类似于java里的反射机制&#xff0c;可以通过字符串比较方便…

5.11 汇编语言:仿写IF条件语句

条件语句&#xff0c;也称为IF-ELSE语句&#xff0c;是计算机编程中的一种基本控制结构。它允许程序根据条件的真假来执行不同的代码块。条件语句在处理决策和分支逻辑时非常有用。一般来说&#xff0c;条件语句由IF关键字、一个条件表达式、一个或多个代码块以及可选的ELSE关键…

java开源 VR全景商城 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城 小程序商城搭建 bbc

​ 1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis 3. 前…

回归预测 | MATLAB实现BES-SVM秃鹰搜索优化算法优化支持向量机多输入单输出回归预测(多指标,多图)

回归预测 | MATLAB实现BES-SVM秃鹰搜索优化算法优化支持向量机多输入单输出回归预测&#xff08;多指标&#xff0c;多图&#xff09; 目录 回归预测 | MATLAB实现BES-SVM秃鹰搜索优化算法优化支持向量机多输入单输出回归预测&#xff08;多指标&#xff0c;多图&#xff09;效…

go gorm一对多has many

has many 与另一个模型建立了一对多的连接。 不同于 has one&#xff0c;拥有者可以有零或多个关联模型。 例如&#xff0c;您的应用包含 user 和 credit card 模型&#xff0c;且每个 user 可以有多张 credit card。 定义model // User 有多张 CreditCard&#xff0c;UserI…

python中的matplotlib画直方图(数据分析与可视化)

python中的matplotlib画直方图&#xff08;数据分析与可视化&#xff09; import numpy as np import pandas as pd import matplotlib.pyplot as pltpd.set_option("max_columns",None) plt.rcParams[font.sans-serif][SimHei] plt.rcParams[axes.unicode_minus]Fa…

TCP缓冲区参数调优

1、系统原值查询 [lybadmin autopush]$ cat /proc/sys/net/core/rmem_max 4194304 [lybadmin autopush]$ cat /proc/sys/net/core/wmem_max 1048576 [lybadmin autopush]$ cat /proc/sys/net/ipv4/tcp_rmem 4096 87380 4194304 [lybadmin autopush]$ cat /proc/sys/net/ip…

centos8安装mysql

1.首先用finalShell远程连接到服务器 2.如果服务器之前安装过mysql请先卸载,我这里是用yum安装的&#xff0c;现在通过yum去卸载 yum remove -y mysql find / -name mysql //找到残留的文件&#xff0c;再通过rm -rf去删除对应的文件3.下面正式开始安装 &#xff08;1&#…

基于微信小程序+Springboot校园二手商城系统设计和实现

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、目前专注于大学生项目实战开发,讲解,毕业答疑辅导✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3…

使用 OpenAI GPT 模型的最佳实践

推荐&#xff1a;使用NSDT场景编辑器助你快速搭建可二次编辑的3D应用场景 为了帮助用户获得最佳输出&#xff0c;OpenAI 提供了使用 GPT 模型的最佳实践。这来自体验&#xff0c;因为许多用户不断尝试使用此模型并找到了最有效的方法。 在本文中&#xff0c;我将总结使用 Ope…

分数规划(二分)

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 小咪是一个土豪手办狂魔&#xff0c;这次他去了一家店&#xff0c;发现了好多好多&#xff08;n个&#xff09;手办&#xff0c;但他是一个很怪的人&#xff0c;每次只想买k个手办&a…

JavaSE-21 【Stream流】

1 Stream的介绍 1.1 概念 stream流操作是Java 8提供一个重要新特性&#xff0c;它允许开发人员以声明性方式处理集合&#xff0c;其核心类库主要改进了对集合类的 API和新增Stream操作。Stream类中每一个方法都对应集合上的一种操作。将真正的函数式编程引入到Java中&#xf…

【PHP】数据类型运算符位运算

文章目录 数据类型简单&#xff08;基本&#xff09;数据类型&#xff1a;4个小类复合数据类型&#xff1a;2个小类特殊数据类型&#xff1a;2个小类类型转换类型判断整数类型浮点类型布尔类型 运算符赋值运算符算术运算符比较运算符逻辑运算符连接运算符错误抑制符三目运算符自…

Apache ShenYu 学习笔记一

1、简介 这是一个异步的&#xff0c;高性能的&#xff0c;跨语言的&#xff0c;响应式的 API 网关。 官网文档&#xff1a;Apache ShenYu 介绍 | Apache ShenYu仓库地址&#xff1a;GitHub - apache/shenyu: Apache ShenYu is a Java native API Gateway for service proxy, pr…

nginx+keepalived负载均衡和高可用配置

概述 nginx用来负载均衡&#xff0c;keepalived是用来实现VIP故障切换。 配置 nginxkeepalived配置中&#xff0c;后端普通服务器不需要lvs实现负载均衡。 在服务器上停止之前的lvs配置 /etc/init.d/lvs_rs stop 1.nginx的配置 在主备节点上测试 配置nginx之前需要将kee…

UE学习记录03----UE5.2 使用MVVM示例

1.打开ue5.2新建C项目 2.项目中通过类导向新建C类&#xff0c;父类选择为UMVVMViewModelBase&#xff0c;创建完成会自动打开vs 3.在VS中对新建的类进行宏定义 使用 C 类向导 创建的类声明自动通过 UCLASS() 宏进行处理。 UCLASS() 宏使得引擎意识到这个类的存在&#xff0c;并…