百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

了解 Oracle 中单引号与双引号的用法,一篇文章教会你!

csdh11 2024-12-08 13:00 17 浏览

无论测试或者开发,对数据库的增删改查都是家常便饭。但有些小知识是经常被忽略,却又不能不去了解的,例如单引号和双引号的用法和区别,看完这一篇,你肯定会有收获。

首先我们要区别一个概念,即单引号(‘)和双引号(“)和两个单引号(‘’),在PL/SQL中明显是不同的,单引号就是单引号,双引号就是双引号。那么我们来看下单引号和双引号在Oracle的世界中有什么区别。

Oracle中的单引号

在Oracle中,单引号主要有两种用途:

一是引用字符串

二是转义

让我们直接从问题出发,反向论证。

Q1 如何打印出单引号?

我们知道单引号经常用来标识内容为字符串(引用),但是怎么来标识自己呢?如果直接这样写,那么就会报错。

select ''' from dual;

> ORA-01756: 引号内的字符串没有正确结束

因此,这边用到了单引号的转义用法,即用单引号转义自己:’’

没错,就是写成两个单引号,转义类似语言中的反斜杠(\),下面SQL中的绿色部分就是转义的位置。

select''''fromdual;

Q2如果转义单引号和字符串的引号连续,如何选择优先级?

如果转义字符前后还有字符串,那么该怎么判断其优先级呢,是先表示字符串的,还是先转义。

select'name''is'fromdual;

例如上面这个SQL,两个字符串连在一起,那么是输出拼接后的nameis还是 name’is?其实这边看似两个字符串,其实中间的两个单引号是转义,所以结果是 name’is. select'name''is'fromdual;#中间引号为转义的单引号

那有没有连续转义的场景呢,例如下面这个sql,就是连续转义。

select'name'''''fromdual;

如上,sql中进行了连续两个转义,因此结果是name''

Q3单引号遇到||拼接还可以继续转义吗?

我们都知道,在sql语句中,如果想要多个字段拼接,可以用双竖线||来实现。而||两边的字符串是没有任何关联的,互不干扰,即使是转义字符也是一样的,可以看到下面这个例子。

select'I'||''''||'amJack'fromdual;

语句中由两个||将字符串分成了3部分,且每段都是互相独立的。那么中间4个单引号是如何显示的?其实是中间两个单引号是转义,前后两个单引号只是字符串的引用而已(4个单引号只为了显示1个单引号),因此结果就是:I'amJack

Q4单引号的转义太复杂,易混乱,有没有简单的标识方法?

对于简单的sql语句中含有个别单引号还可以接受,但是如果sql语句中包含大量的单引号,岂不是很混乱,要崩溃?

select'insertintobp_data_router(ACCESS_TYPE,ACCESS_CODE,BE_ID,EFF_DATE,CUST_ID_PREFIX,EXP_DATE,STATUS,CUST_ID)values('||''||t.access_type||','''||t.access_code||''','||t.be_id||',to_date('''||to_char(t.eff_date,'yyyymmddhh24miss')||''','||'''yyyymmddhh24miss''),'||t.cust_id_prefix||','||'to_date('''||to_char(t.exp_date,'yyyymmddhh24miss')||''','||'''yyyymmddhh24miss''),'''||t.status||''','||t.cust_id||');'frombp_data_routertwhereto_char(t.eff_date,'yyyymmddhh24miss')>'20170119004300'andt.eff_date<sysdate

对于类似复杂场景,为了避免出错,建议使用ASCII码来表示:chr(39)

selectchr(39)fromdual;#’

Oracle中的双引号

一般来说,双引号没有单引号那么复杂,它就是一个普通的字符。

select'"'fromdual;

但是,当出现在to_char的格式字符串中时,双引号有特殊的作用,就是将非法的格式符包装起来,避免出现ORA-01821:dateformatnotrecognized错误。?也就是说,去掉双引号和其包含的字符后,剩下的应该是一个合法的格式串。此时,to_char在处理格式字符串时,会忽略双引号。

selectto_char(sysdate,'hh24"小时"mi"分"ss"秒"')resultsfromdual;

如上这个写法,“小时”这部分是不能带入到语言内部运算的,程序会默认忽略这部分字符,但是输出的时候,又把它们加上,这就是双引号的作用。

#忽略之后执行这样的语句:

selectto_char(sysdate,'hh24miss')resultsfromdual;

#输出结果再加上双引号的格式:

>>22小时50分59秒

总结:

综上所述,Oracle中的单引号可以充当转义字符,且优先级较高,而双引号只是个普通字符,只有在to_char中才能发挥特别作用。

最后:

1)关注+私信回复:“测试”,可以免费领取一份10G软件测试工程师面试宝典文档资料。

2)关注+私信回复:"入群" 就可以邀请你进入软件测试群学习交流~~

相关推荐

IDEA界面太丑??尝试一下这几个插件

前言IntelliJIDEA主要用于支持Java、Scala、Groovy等语言的开发工具,同时具备支持目前主流的技术和框架,擅长于企业应用、移动应用和Web应用的开发。IntelliJi...

小巧 Vue 页面滚动进度条组件ScrollProgress

今天给大家分享一个轻量级Vue.js全屏滚动进度条组件VueScrollProgress。vue-scroll-progress一款基于vue.js构建的页面滚动进度条组件,...

基于vue实现可视化拖拽编辑器,页面生成工具,提升前端开发效率

项目介绍基于vue实现的可视化拖拽编辑器,实现页面生成工具,提升前端开发效率。可以基层到移动端项目作为自定义json直接生成UI页面。项目特点功能特点...

优秀 vue+heyui 后端管理系统HeyUI-Admin

今天再给小伙伴们推荐一款成熟的企业中后台管理系统HEYUI-Admin。heyui-admin基于vue.js和heyui组件库构建的后台管理系统。包含基础表单/表格功能,拓展组件(图表、富文本编辑...

响应式 Vue.js 前端组件化框架Xvue-UI

今天给小伙伴们推荐一款超不错的Vue轻量级组件框架XVueUI。xvue-ui基于vue2.x构建的响应式前端组件化框架。轻量级、易于上手,提供...

《基于SpringBoot+Vue的在线视频系统设计与实现》开题报告

【计算机毕业设计案例】基于SpringBoot+Vue的在线视频系统设计与实现_哔哩哔哩_bilibili...

超好用 Vue.js 图片裁切组件Vue-ImgCutter

今天给小伙伴们分享一个超棒的Vue图片任意裁剪插件VueImgCutter。vue-img-cutter基于vue2.x构建的轻量级剪切图片组件。支持移动图像、放大缩小图片、任意移动图片、固定比...

Vue 3 进阶用法:异步组件(vue 异步组件原理)

一、代码分割一个大型前端应用,如果所有代码都放在单一文件,体积会特别大,下载时间长,白屏时间久,用户体验差。...

源码补丁神器—patch-package(源码助手怎么用)

作者:张浩一、背景vue项目中使用vue-pdf第三方插件预览pdf,书写业务代码完美运行,pdf文件内容正常预览无问题。后期需求有变,业务需求增加电子签章功能。这个时候pdf文件的内容可以显示出...

经验分享:Vue2 项目升级 Vue3 + Element Plus,借助Deepseek手动升级

Vue3出来好久了,我开发的项目还在使用Vue2框架,一般情况下不考虑升级,但是最近需要接入工作流程引擎之类的,看了下Vue2生态下操作空间不是很好,那索性尝试升级Vue3吧。一番操作下来,升级成功,...

34K Star!史上最全JavaScript资源库 awesome-javascript

34KStar!史上最全JavaScript资源宝库大揭秘引言在GitHub上,有一个备受瞩目的JavaScript资源仓库,以其全面的内容和精心的分类,成为了众多开发者的必备参考。这个拥有超过...

基于 Vue.js 磁片栅格布局组件VueGridLayout

#头条创作挑战赛#今天给大家分享一个超优秀的vue.js拖拽栅格布局插件VueGridLayout。...

6款高颜值 Vue3 PC端UI组件库(vue3开发组件库)

马上到国庆了,还没学习或者想学习vue3的小伙伴们有安排上没?这次推荐几个比较流行的VUE3UI组件库,合理利用,又或者学习借鉴都是不错的选择。1、element-pluselement-plus...

高性能 vue.js+ztree 树形组件Vue-GiantTree

今天给大家分享一款超棒的Vue海量数据渲染树形组件VueGiantTree。vue-giant-tree基于ztree封装的Vue树形组件。轻松实现大数据高性能渲染,适合海量数据渲染场景。zTr...

【推荐】2024年推荐的6款开源免费 Vue 后台管理系统模板,建议收藏

前言在现今的软件开发领域,...