数据库之基本功:Where 中常用运算符

news2025/7/23 16:34:43

1. 运算符及优先级

 ( )优先级最高

SQL> show user;
USER is "SCOTT"
SQL> select ename, job, sal, comm from emp where job='SALESMAN' OR job='PRESIDENT' and sal> 1500;

ENAME                          JOB                                SAL       COMM
------------------------------ --------------------------- ---------- ----------
ALLEN                          SALESMAN                          1600        300
WARD                           SALESMAN                          1250        500
MARTIN                         SALESMAN                          1250       1400
TURNER                         SALESMAN                          1500          0

SQL> 

知识点:条件子句使用比较运算符比较两个选项,重要的是要理解这两个选项的数据类型。

2.BETWEEN AND

查询出在某一范围内的行.

-- between低值and高值, 包括低值和高值.

SQL> SELECT ename, sal FROM emp WHERE sal BETWEEN 1000 AND 1500;

ENAME                                 SAL
------------------------------ ----------
WARD                                 1250
MARTIN                               1250
TURNER                               1500
ADAMS                                1100
MILLER                               1300

SQL> 

3. %模糊查询及其通配符:

在where字句中使用like谓词,常使用特殊符号"%"或"_"匹配查找内容

SQL> 
SQL> create table test (name char (10));
insert into test values ('sFdL');
insert into test values ('AEdLHH');
insert into test values ('A%dMH');

Table created.

SQL> 
1 row created.

SQL> 
1 row created.

SQL> 
1 row created.

SQL> insert into test values('Jack');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from test;

NAME
------------------------------
sFdL
AEdLHH
A%dMH
Jack

SQL> select * from test where name like 'A%';

NAME
------------------------------
AEdLHH
A%dMH

SQL> select * from test where name like '%A%';

NAME
------------------------------
AEdLHH
A%dMH

SQL> 

4. 转义通配符\或/

使用escape \可以取消特殊符号如%的作用.

SQL> 
SQL> -- \%.将A%dMH里的%转义,或者将\换成/也可以.自定义转义符.
SQL> select * from test where name like 'A\%%' escape '\';

NAME
------------------------------
A%dMH

SQL> select * from test where name like '%\%%' escape '\';

NAME
------------------------------
A%dMH

SQL>

5. 连接符||

SQL> 
SQL> select empno||' is Scott''s empno' from emp where empno=7788;

EMPNO||'ISSCOTT''SEMPNO'
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------
7788 is Scott''s empno

SQL> select empno||ename from emp where empno=7788;

EMPNO||ENAME
------------------------------------------------------------------------------------------------------------------------------------------------------
7788SCOTT

SQL>

6. Q-quote

Oracle还提供了一个Q-quote的表达式.来简化SQL或PLSQL中字符串的表示.其格式为q'[字符串]',输出为方括号中的原始字符串格式.其中方括号可以更换为其他的任意一对特殊符号.

SQL> 
SQL> select q'[God isn''t a girl]' name from dual;

NAME
---------------------------------------------------
God isn''t a girl

SQL> select q'\God isn''t a girl\' name from dual;

NAME
---------------------------------------------------
God isn''t a girl

SQL> select q'+God isn''t a girl+' name from dual;

NAME
---------------------------------------------------
God isn''t a girl

SQL> select q'2God isn''t a girl2' name from dual;

NAME
---------------------------------------------------
God isn''t a girl

SQL>

7. '' 和" "的用法:

''内表示字符或日期数据类型;
而"" 一般用于别名中有大小写、保留字、空格等场合,引用recyclebin中的《表名》也需要" ".

单引号的转义:连续两个单引号表示转义.

sql中字符串的两边是需要加单引号的.表示字符串的开始和结束.如果我们想在sql中输出一个实际的单引号’,那么需要连续输入四个单引号’’’’.其中中间的两个单引号表示一个单引号.
第一个单引号:表示字符串开始
第二个单引号:表示转义.后面接的单引号转义为真正的单引号
第三个单引号:表示实际输出的单引号
第四个单引号:表示字符串结束

SQL> select '''' N from dual;

N
---
'

SQL> select 'God isn''t a girl'name from dual;

NAME
------------------------------------------------
God isn't a girl

SQL>

8. 使用逻辑操作符: AND, OR, NOT

AND 两个条件都为TRUE ,则返回TRUE
OR 两个条件中任何一个为TRUE,则返回TRUE
NOT 如果条件为FALSE,返回TRUE

SQL> 
SQL> 
SQL> SELECT empno, ename, job, sal FROM emp WHERE sal>=1100 AND job= 'CLERK';

     EMPNO ENAME                          JOB                                SAL
---------- ------------------------------ --------------------------- ----------
      7876 ADAMS                          CLERK                             1100
      7934 MILLER                         CLERK                             1300

SQL> SELECT empno, ename, job, sal FROM emp WHERE sal>=1100 OR job = 'CLERK';

     EMPNO ENAME                          JOB                                SAL
---------- ------------------------------ --------------------------- ----------
      7369 SMITH                          CLERK                              800
      7499 ALLEN                          SALESMAN                          1600
      7521 WARD                           SALESMAN                          1250
      7566 JONES                          MANAGER                           2975
      7654 MARTIN                         SALESMAN                          1250
      7698 BLAKE                          MANAGER                           2850
      7782 CLARK                          MANAGER                           2450
      7788 SCOTT                          ANALYST                           3000
      7844 TURNER                         SALESMAN                          1500
      7876 ADAMS                          CLERK                             1100
      7900 JAMES                          CLERK                              950
      7902 FORD                           ANALYST                           3000
      7934 MILLER                         CLERK                             1300

13 rows selected.

SQL> SELECT ename, job FROM emp WHERE job NOT IN ('CLERK', 'MANAGER', 'ANALYST');

ENAME                          JOB
------------------------------ ---------------------------
ALLEN                          SALESMAN
WARD                           SALESMAN
MARTIN                         SALESMAN
TURNER                         SALESMAN

SQL>

9.用IN操作符检验某值是否在某列表中

SQL> 
SQL> SELECT empno,ename,sal,mgr from emp where mgr IN (7902, 7566, 7788);

     EMPNO ENAME                                 SAL        MGR
---------- ------------------------------ ---------- ----------
      7369 SMITH                                 800       7902
      7788 SCOTT                                3000       7566
      7876 ADAMS                                1100       7788
      7902 FORD                                 3000       7566

SQL>

10. 交互输入变量符&和&&的用途

10.1 &两种写法

-- 输入 empnumber 的值:  7788,其中&后可以写任意字符

SQL> 
SQL> select empno,ename from emp where empno=&empnumber;
Enter value for empnumber: 7788
old   1: select empno,ename from emp where empno=&empnumber
new   1: select empno,ename from emp where empno=7788

     EMPNO ENAME
---------- ------------------------------
      7788 SCOTT

SQL> set verify off;
SQL> select empno,ename from emp where empno=&empnumber;
Enter value for empnumber: 7788

     EMPNO ENAME
---------- ------------------------------
      7788 SCOTT

SQL> 

-- &后面是字符型的,注意单引号问题,可以有两种写法:
-- 1、 带''输入emp_name 的值:  SCOTT
SQL> select empno,ename from emp where ename='&emp_name';
EMPNO    ENAME
-----    -----
7788    SCOTT
-- 2、 不带''输入emp_name 的值要加'':  ‘SCOTT’
SQL> select empno,ename from emp where ename=&emp_name;
EMPNO    ENAME
-----    -----
7788    SCOTT

SQL> 
SQL> select empno,ename from emp where ename='&emp_name';
Enter value for emp_name: SCOTT

     EMPNO ENAME
---------- ------------------------------
      7788 SCOTT

SQL>
SQL> select empno,ename from emp where ename=&emp_name;
Enter value for emp_name: 'SCOTT'

     EMPNO ENAME
---------- ------------------------------
      7788 SCOTT

SQL> 

10.2 set verify off

如果不想显示"原值"和"新值"的提示,可以使用set verify on|off命令

-- 去掉 原值、新值 提示语

SQL> 
SQL> set verify off;
SQL> select empno, ename from emp where ename='&emp_name';
Enter value for emp_name: SCOTT

     EMPNO ENAME
---------- ------------------------------
      7788 SCOTT

SQL> 

10.3 &&存储定义

&&存储了第一次输入值,使后面的相同的&不再询问,自动取代.

-- 输入 salary 的值:sal	//&后的字符定义了要输入的查询列
SQL> select empno,ename,&&salary from emp where deptno=10 order by &salary; 
Enter value for salary: sal	-- 第一次询问,define了sal	
EMPNO 	ENAME	SAL
-----	------	-----
7934 	MILLER	1300
7782 	CLARK	2450
7839 	KING	5000
SQL> select empno, ename, &&salary from emp where deptno=10 order by &salary;
EMPNO 	ENAME	SAL			-- 第二次不在询问
-----	------	-----
7934 	MILLER	1300
7782 	CLARK	2450
7839 	KING	5000

10.4 define定义变量

-- 定义变量
SQL> 
SQL> show user;
USER is "SCOTT"
SQL> show con_name;

CON_NAME
------------------------------
PDB1
SQL> define emp_num=7788
SQL> select empno,ename,sal from emp where empno=&emp_num;

     EMPNO ENAME                                 SAL
---------- ------------------------------ ----------
      7788 SCOTT                                3000

SQL> 

10.5 define查询定义变量

-- 显示当前已经定义的变量(包括默认值)
SQL> 
SQL> define
DEFINE _DATE           = "07-MAR-23" (CHAR)
DEFINE _CONNECT_IDENTIFIER = "PDB1" (CHAR)
DEFINE _USER           = "SCOTT" (CHAR)
DEFINE _PRIVILEGE      = "" (CHAR)
DEFINE _SQLPLUS_RELEASE = "1903000000" (CHAR)
DEFINE _EDITOR         = "vi" (CHAR)
DEFINE _O_VERSION      = "Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0" (CHAR)
DEFINE _O_RELEASE      = "1903000000" (CHAR)
DEFINE SALARY          = "sal" (CHAR)
DEFINE EMP_NUM         = "7788" (CHAR)
SQL> 

10.6 define开关和解除

注:上面给的 &salary已经在当前session下存储了,可以使用undefine salary解除.
define(定义变量)和undefine命令(解除变量)

SQL> define
DEFINE _DATE           = "07-MAR-23" (CHAR)
DEFINE _CONNECT_IDENTIFIER = "PDB1" (CHAR)
DEFINE _USER           = "SCOTT" (CHAR)
DEFINE _PRIVILEGE      = "" (CHAR)
DEFINE _SQLPLUS_RELEASE = "1903000000" (CHAR)
DEFINE _EDITOR         = "vi" (CHAR)
DEFINE _O_VERSION      = "Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0" (CHAR)
DEFINE _O_RELEASE      = "1903000000" (CHAR)
DEFINE SALARY          = "sal" (CHAR)
DEFINE EMP_NUM         = "7788" (CHAR)
SQL> 
SQL> undefine emp_num
SQL> undefine SALARY
SQL> 
SQL> define
DEFINE _DATE           = "07-MAR-23" (CHAR)
DEFINE _CONNECT_IDENTIFIER = "PDB1" (CHAR)
DEFINE _USER           = "SCOTT" (CHAR)
DEFINE _PRIVILEGE      = "" (CHAR)
DEFINE _SQLPLUS_RELEASE = "1903000000" (CHAR)
DEFINE _EDITOR         = "vi" (CHAR)
DEFINE _O_VERSION      = "Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0" (CHAR)
DEFINE _O_RELEASE      = "1903000000" (CHAR)
SQL> 

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

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

相关文章

Pyspark基础入门5_RDD的持久化方法

Pyspark 注:大家觉得博客好的话,别忘了点赞收藏呀,本人每周都会更新关于人工智能和大数据相关的内容,内容多为原创,Python Java Scala SQL 代码,CV NLP 推荐系统等,Spark Flink Kafka Hbase Hi…

回收站清空恢复,4种方法任你选!

案例:不小心清空了回收站怎么恢复? “回收站刚刚清空的文件怎么恢复呀?辛苦收集的材料不小心删除了,请大神来帮我下。” 回收站是我们电脑上的一个非常实用的功能,可以让我们暂时存放不需要的文件或者是可以被删除的…

启动u盘还原成普通u盘(Windows Diskpart)

使用windows系统的diskpart 命令解决系统盘恢复成普通U盘的问题:1. 按Windows R键打开运行窗口。在搜索框中输入“ Diskpart ”,然后按 Enter 键。2. 现在输入“ list disk ”并回车。3. 然后输入“ select disk X ”(将 X 替换为可启动U盘的…

围棋高手郭广昌的“假眼”棋局

(图片来源于网络,侵删)文丨熔财经作者|易不二2022年,在复星深陷债务压顶和变卖资产漩涡的而立之年,“消失”已久的郭广昌,在质疑与非议声中回国稳定军心,强调复星将在未来的五到十年迎来一个全新…

安卓反编译入门03-dex2jar反编译apk得到Java源代码

1.获取工具dex2jar下载地址:http://sourceforge.net/projects/dex2jar/files/直接下载下载完成后,解压得到文件夹dex2jar-2.0jd-gui下载地址:http://jd.benow.ca/ 直接下载(官网版本无法复制中文,可以用这个&#xff0…

K8s pod 动态弹性扩缩容 HPA

一、概述Horizontal Pod Autoscaler(HPA,Pod水平自动伸缩),根据平均 CPU 利用率、平均内存利用率或你指定的任何其他自定义指标自动调整 Deployment 、ReplicaSet 或 StatefulSet 或其他类似资源,实现部署的自动扩展和…

算法练习-二分查找(二)

算法练习-二分查找(二) 文章目录算法练习-二分查找(二)1 二分查找1.1 题目1.2 题解2 猜数字大小2.1 题目2.2 题解3 寻找比目标字母大的最小字母3.1 题目3.2题解4 搜索插入位置4.1 题目4.2 题解5 在排序数组中查找元素的第一个和最后一个位置5.1 题目5.2 …

34- PyTorch数据增强和迁移学习 (PyTorch系列) (深度学习)

知识要点 对vgg 模型进行迁移学习定义数据路径: train_dir os.path.join(base_dir, train) # base_dir ./dataset 定义转换格式: transform transforms.Compose([transforms.Resize((96, 96)), # 统一缩放transforms.ToTensor(), # 转换为tensortransforms.No…

如何查找你的IP地址?通过IP地址能直接定位到你家!

我们ip地址分为A、B、C、D、E共5类,每一类地址范围不同,从A到Eip地址范围依次递减,其中哦,D和E是保留地址,我们用不了。A、B、C3类地址很多都被美国这样的西方国家分走了,而留给我们的就剩有限的地址了&…

记一次接口远程调用异常排查链路 Remote peer closed connection before all data could be read

前言: 异常信息: java.io.IOException: UT000128: Remote peer closed connection before all data could be read 在九月份-十月初一直都被这个问题困扰~ 排查链路 第一次、二次、三次排查该问题: 当时看到”Remote peer c…

支持在局域网使用的项目管理系统有哪些?5款软件对比

一、选择私有部署的原因以及该方案的优点有很多可能的原因导致人们更倾向于使用私有部署的企业管理软件,其中一些原因可能包括:1.数据安全性要求:一些企业管理软件包含敏感的商业数据和隐私信息,为了保护这些信息不被未经授权的第…

MyBatisPlus中的条件构造器Wrapper

引言为什么要了解Wrapper?Wrapper解决的了什么问题?一、Wrapper:条件构造抽象类,用来解决单表操作出现的一些复杂问题,例如排序,和模糊查询等等结构图文字解释AbstractWrapper : 用于查询条件封装&#xff…

java设计模式学习

一、设计模式7大原则1.单一职责原则 (Single Responsibility Principle) 在类级别和方法级别进行职责规划,专人专事2.开放-关闭原则 (Open-Closed Principle) 增加接口功能时,尽可能不要修改原有代码3.里氏替换原则 (Liskov Substitution Principle) 子类…

华为HCIE学习之Openstack keystone组件

文章目录一、keystone对象模型二、使用token的好处Token的实现模式1、UUID Token,每次验证需要访问keystone服务端2、PKI Token 验证,在客户端即可完成 发放公钥 私钥解密3、RBAC三、policy.json权限实验一、keystone对象模型 二、使用token的好处 1、token缓存在客…

什么是数字化?企业如何实现数字化?

随着社会的发展与时代的进步,以生产为核心的企业也在进行不断的创新,而新一代信息技术的应用深化,制造业迎来了数字化转型新机遇。数字化转型近些年更多的被提及,越来越多的企业想通过数字化的转型,降低企业运营成本&a…

《Ansible变量篇:ansible中事实变量facts》

一、简介 facts组件是ansible用于采集被管理机器设备信息的一个功能, 采集的机器设备信息主要包含IP地址,操作系统,以太网设备,mac地址,时间/日期相关数据,硬件信息等。 ansible有一个模块叫setup,用于获取远程主机的相关信息,并可以将这些信息作为变量在playbook里进行调用,而…

【python】剑指offer代码大集合

剑指 Offer(第 2 版) https://leetcode.cn/problem-list/xb9nqhhg/ 剑指 Offer 03. 数组中重复的数字 https://leetcode.cn/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof/ # 法1:哈希表(Set) class Solution:def findRepeatNumber(self, nums: [

CentOS8基础篇12:使用RPM管理telnet-server软件包

一、RPM包管理工具简介 RedHat软件包管理工具(RedHat Package Manager,RPM) RPM软件包工具常用于软件包的安装、查询、更新升级、校验、卸载以及生成.rpm格式的软件包等操作。 RPM软件包工具只能管理后缀是.rpm的软件包。软件包的命名格式: 软件名称…

java 实现pgsql数据库免密备份 Windows版本

阐述下背景: 最近公司项目中有个功能模块,需要使用java实现pgsql数据库整库的数据备份,没有pgsql使用经验的我,在网上寻找了好多大神的帖子,也没发现适合自己当前场景的解决方案,但是我把大神们的帖子按照自…

某开源远程办公软件安装配置说明

******是开源软件,只需要简单的配置,就可以在企业搭建SSL VPN,满足日常远程办公的需求。本篇文档为在windows服务器安装搭建openvpn记录,仅供参考。 拓扑说明 使用虚拟机进行测试,主机操作系统Windows 10和m0n0。模拟…