截取字符串SUBSTR(),INSTR()使用总结

2024-03-02 19:58

本文主要是介绍截取字符串SUBSTR(),INSTR()使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基本语法

1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串
   解释: string 元字符串
              start_position   开始位置(从0开始)

              length 可选项,子字符串的个数

2.INSTR(string,subString,position,ocurrence)查找字符串位置
   解释:string:源字符串
             subString:要查找的子字符串
             position:查找的开始位置(从1开始)

             ocurrence:源字符串中第几次出现的子字符串

注:截取函数都是从左向右截取字符,当起始位置为负数时,意为按字符串从右往左的指定位置开始从左往右截取;
例如:字符串msg:123456789

substr(msg,-6,3)意思是从倒数(从右往左)的第六位4开始(从左往右)截取3位,结果为:456;

二、举例说明

1.由于某种原因导致巡视记录缺失,现需要从日志文件(logtable)中计算巡视结果并将其导入巡视记录表(patrolpoletable)

logtable表中的数据:

INSDATEMSG
04-12月-14微机室特殊巡视:Ⅱ徐丁线 26#杆塔完成,时间:2014-11-05 :16:17:23,113586092,34749988,
22-1月 -15运行一班特殊巡视:密侯线 36#杆塔完成,时间:2014-12-09 :09:53:54,113476920,34534262,
22-1月 -15

运行一班特殊巡视:Ⅰ鹅密线 36#杆塔完成,时间:2014-12-09 :10:11:01,113397681,34508912,

patrolpoletable表中的数据:

circuitrynamepoleidLBpatraldatepeopleteshuidxnoidxnocode
Ⅱ联慈线8113.07995534.77719724-2月 -16张三13684101368
Ⅰ联慈线 8113.07999234.77721324-2月 -16李四13684101369

执行语句:

INSERT INTO patrolpoletable(circuitryname,poleid,L,B,patraldate,people,teshu,idxno,idxnocode)
SELECT circuitryname,poleid,l,b,patraldate,people,teshu,idxno,idxnocode
FROM(SELECT circuitryname,poleid,l,b,patraldate,people,1 AS teshu ,116057+rownum AS idxno ,'4101'||TO_CHAR(116057+rownum) AS idxnocodeFROM v_log_xunsjl aWHERE NOT EXISTS(SELECT circuitryname,poleid,l,b,patraldate,peopleFROM PATROLPOLETABLE bWHERE a.circuitryname=b.circuitryname AND a.poleid = b.poleidAND a.patraldate =b.patraldateAND a.people = b.people)AND TO_CHAR(a.patraldate,'yyyy-mm-dd')>='2018-01-01')a
WHERE a.circuitryname IS NOT NULL; 

显示结果:


注:因为日志文件里存储了所有的日志信息,所以这里我创建了一个视图(v_log_xunsjl),用来将日志文件中的巡视记录提取出来;




这篇关于截取字符串SUBSTR(),INSTR()使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767260

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核