oracle 正则表达式匹配日期格式,利用正则表达式找出不合符的日期

很多时候我们的日期可能存放的是字符串类型,在插入的时候也很有可能插入的日期格式不正确,

因此我们需要找出这些不合符的日期格式,来此来修正。当然可以使用TO_DATE函数一个一个的转换来找出不合法的日期。ORACLE提供了正则表达式,正则表达式在处理不合符的IP ,手机号,EMAIL等大有用处。

此处我们用正则表达式找出不合法的日期格式。

SQL> conn ysp/ysp

Connected.

SQL> select * from v$version;

BANNER

----------------------------------------------------------------------------------------------------

Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi

PL/SQL Release 10.2.0.4.0 - Production

CORE    10.2.0.4.0      Production

TNS for IBM/AIX RISC System/6000: Version 10.2.0.4.0 - Productio

NLSRTL Version 10.2.0.4.0 - Production

SQL> create table  regexp_test(datecol char(19));

Table created.

SQL> insert into regexp_test select LAST_DDL_TIME  from user_objects where rownum<=10;

10 rows created.

SQL> commit;

Commit complete.

SQL> select * from regexp_test;

DATECOL

--------------------------------------

2010-07-06 16:56:07

2010-06-12 16:16:36

2010-06-12 13:44:14

2010-06-12 14:23:33

2010-06-12 14:48:21

2010-07-26 10:44:27

2010-06-04 10:20:03

2010-06-04 13:22:31

2010-06-04 10:26:31

2010-06-04 13:50:02

10 rows selected.

此处我们用YYYY-MM-DD HH24:MI:SS作为我们的日期格式,其他格式为非法。

SQL> update regexp_test set datecol='2010-00-06 16:56:07' where datecol='2010-07-06 16:56:07';

1 row updated.

SQL> update regexp_test set datecol='2010-06-00 16:16:36' where datecol='2010-06-12 16:16:36';

1 row updated.

SQL> update regexp_test set datecol='2010-06-12 24:44:14' where datecol='2010-06-12 13:44:14';

1 row updated.

SQL> update regexp_test set datecol='2010-06-12 14:60:33' where datecol='2010-06-12 14:23:33';

1 row updated.

SQL> update regexp_test set datecol='2010-06-12 14:48:67' where datecol='2010-06-12 14:48:21';

1 row updated.

SQL> commit;

Commit complete.

SQL> insert into regexp_test values('2010-06-04:13:50:02');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from regexp_test;

DATECOL

---------------------------

2010-00-06 16:56:07  --月份不合法

2010-06-00 16:16:36  --日子不合法

2010-06-12 24:44:14  --小时不合法

2010-06-12 14:60:33  --分钟不合法

2010-06-12 14:48:67  --秒数不合法

2010-07-26 10:44:27

2010-06-04 10:20:03

2010-06-04 13:22:31

2010-06-04 10:26:31

2010-06-04 13:50:02

2010-06-04:13:50:02  --格式不合法

11 rows selected.

找出合法的日期

SQL> select * from regexp_test

2  where regexp_like(datecol,'^([0-9]{4})-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3[0-1])) (([0-1][0-9])|(2[0-3])):([0-5][0-9]):([0-5][0-9])$');

DATECOL

--------------------------------------

2010-07-26 10:44:27

2010-06-04 10:20:03

2010-06-04 13:22:31

2010-06-04 10:26:31

2010-06-04 13:50:02

找出不合法的日期

SQL> select * from regexp_test

2  where not regexp_like(datecol,'^([0-9]{4})-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3[0-1])) (([0-1][0-9])|(2[0-3])):([0-5][0-9]):([0-5][0-9])$');

DATECOL

--------------------------------------

2010-00-06 16:56:07

2010-06-00 16:16:36

2010-06-12 24:44:14

2010-06-12 14:60:33

2010-06-12 14:48:67

2010-06-04:13:50:02

6 rows selected.

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

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

相关文章

cx oracle 中文 u,cx\U Oracle永久连接

我有一个任务是用cxu Oracle为两个进程创建持久连接。在它需要在同一事务中执行来自第一个进程的一些请求&#xff0c;延迟来自第二个进程的一些请求。在如中所述尝试使用DRCP时下一个代码&#xff1a;#coding: utf-8import cx_Oraclecon1 cx_Oracle.connect(user/pass:127.0.…

oracle amm和asmm,AMM与ASMM

一、AMM相关知识&#xff1a;1.从oracle 11.1开始oracle提供了通过MEMORY_TARGET参数实现自动SGA和PGA自动管理的功能&#xff0c;从此版本开始不再需要明确设置SGA_TARGET及PGA_AGGREGATE_TARGET&#xff0c;这个被支持在linux、windows、solaris、hpux、aix。2.在使用MEMORY_…

oracle display set,Check if the DISPLAY variable is set

1.oracle安装报错如下&#xff1a;Checking Temp space: must be greater than 120 MB. Actual 109499 MB PassedChecking swap space: must be greater than 150 MB. Actual 8191 MB PassedChecking monitor: must be configured to display at least 256 colors>…

linux 系统改名,linux改名命令

弹性云服务器 ECS弹性云服务器(Elastic Cloud Server)是一种可随时自助获取、可弹性伸缩的云服务器&#xff0c;帮助用户打造可靠、安全、灵活、高效的应用环境&#xff0c;确保服务持久稳定运行&#xff0c;提升运维效率三年低至5折&#xff0c;多种配置可选了解详情弹性云服务…

linux确定刻录机目录,在Linux操作系统下使用DVD刻录机(转)

在Linux操作系统下使用DVD刻录机(转)[more]  现在&#xff0c;越来越多的用户开始装备DVD刻录机。在Windows平台上使用DVD刻录机应该不存在什么问题&#xff0c;那么在Linux平台又应该如何使用DVD刻录机呢&#xff1f;一、安装要想在Linux环境中使用DVD刻录机&#xff0c;先必…

linux操作系统网络,网络安装linux操作系统

网络安装安装的准备首先配仓库然后需要安装的服务Yun y install tftp-serverYum y install dhcp开始实验配仓库安装tfpt包并进行配置Tftp-server dhcp tftp后&#xff0c;会在/var/lib/tftpboot这个文件&#xff0c;这个文件是作为linux安装的引导文件&#xff0c;将/mnt/isoli…

Linux使用ftp传输10g的文件,Ubuntu 16.04 安装ftp服务器传输文件

最近在搞深度学习&#xff0c;老师比较宝贝他的服务器&#xff0c;要求我以后负责管理服务器。往后所有要使用服务器的人都必须向我申请账号&#xff0c;然后只允许客户端访问&#xff0c;使用文件传输软件传输文件。像我这样一个Linux菜逼&#xff0c;这种要求不是赶鸭子上架嘛…

linux ks脚本,kickstar-KS文件和语法解析

# KS文件和语法解析[TOC]## 1ks说明### 1.1ks文件说明使用kickstart&#xff0c;只需事先定义好一个Kickstart自动应答配置文件ks.cfg(通常存放在安装服务器上)&#xff0c;并让安装程序知道该配置文件的位置&#xff0c;在安装过程中安装程序就可以自己从该文件中读取安装配置…

linux打印服务叹号,linux中如何通过echo输出!(叹号)? -bash: !: event not found

需求描述:今天在做通过echo结合passwd给用户改密码的过程中,出现无法修改的错误.错误如下:[roottestvm ~]# useradd mytest[roottestvm ~]# echo "mytest!" | passwd --stdin mytest-bash: !": event not found错误分析:经过查找该命令发现叹号!在linux中有特殊…

linux磁盘资源,liunxCPU和内存,磁盘等资源,

liunxCPU和内存&#xff0c;磁盘等资源&#xff0c;1.Screen是一款由GNU计划开发的用于命令行终端切换的自由软件。用户可以通过该软件同时连接多个本地或远程的命令行会话&#xff0c;并在其间自由切换。GNU Screen可以看作是窗口管理器的命令行界面版本。它提供了统一的管理多…

linux降低线程优先级,Linux线程优先级,行为不正常

在下面的代码片段中&#xff0c;我创建了6个线程。各有不同的优先级。全局优先级数组中提到了优先级。我正在根据线索索引在每个线程内连续增加全局变量。如果线程优先级更高&#xff0c;我期待计数更高。但我的输出不遵循优先概念pl。请参阅下面显示的输出顺序。我在Ubuntu 16…

linux非阻塞等待线程,linux – 即使异步I / O操作挂起,只有线程处理io_service正在等待...

这是一个错误.我已经能够通过在task_io_service :: do_poll_one的非关键部分添加延迟来复制它.以下是booost/asio/detail/impl/task_io_service.ipp中修改后的task_io_service :: do_poll_one()的片段.添加的唯一行是sleep.std::size_t task_io_service::do_poll_one(mutex::sc…

linux创建文件内容三行,shell之创建文件及内容的方法示例

shell之创建文件夹&#xff1a;[rootvbox-nginx shell_command]# vi ./mkdir.sh#!/bin/shparentDir"/media/sf_Project/self/smarty-frame/application/$1"fileName$2dirAndName$parentDir/$fileNameif [ ! -d "$dirAndName" ];thenmkdir $dirAndNameecho …

linux设备模型的主要功能,Linux设备模型(3)

Linux设备模型(3)_Uevent作者&#xff1a;蜗蜗 发布于&#xff1a;2014-3-10 20:39分类&#xff1a;统一设备模型1. Uevent的功能Uevent是Kobject的一部分&#xff0c;用于在Kobject状态发生改变时&#xff0c;例如增加、移除等&#xff0c;通知用户空间程序。用户空间程序收到…

lua_path环境变量设置linux,ubuntu16.04安装lua环境

1.官网下载源码 https://www.lua.org/download.htmlcurl -R -O http://www.lua.org/ftp/lua-5.3.5.tar.gztar zxf lua-5.3.5.tar.gzcd lua-5.3.5make linux test2.安装中报错lua.c:82:31: fatal error: readline/readline.h: 没有那个文件或目录compilation terminated.: recip…

动态度量 linux,动态可信度量.ppt

动态可信度量提纲 静态可信度量根 动态可信度量根 Flicker: Minimal TCB Code Execution 静态可信度量的问题 2006年&#xff0c;德国Dresden大学的研究者发现现有的静态可信度量根存在着如下缺陷&#xff1a; 引导装载程序(Bootloader)中存在bug Dartmouth的Bear project的可信…

linux svn 面板,Linux下SVN服务器搭建(CentOS+Subversion)

安装(centos下yum即可方便的完成安装)# yum install subversion测试安装是否成功&#xff1a;# svnserve --version 回车显示版本说明安装成功建立版本库# mkdir /svndata 创建svn数据目录(目录可自行制定)# svnadmin create /svndata/kumingkuming就是版本库的名字&#xff0c…

华为手机怎么下载linux命令,在linux命令

REMOTE_DIR为将根证书上传到弹性云服务器的文件目录。 Windows操作系统下&#xff0c;请使用远程连接工具上传根证书。 连接数据库实例。 方式一&#xff1a;通过Linux命令连接实例 ./mongo --host--port-u-p--authentic目录。 Windows操作系统下&#xff0c;请使用远程连接工具…

edHat linux光盘引导,[原]个性化Linux发行版光盘之补充——XZ(LZMA算法)

红帽(Red Hat)从Enterprise Server 6.2 开始&#xff0c;启动镜像文件initrd.img 开始改用xz 工具进行压缩&#xff0c;这与以往版本是有区别的。一、启动镜像initrd.img 文件类RedHat 系统从vmlinuz 核心引导后&#xff0c;会读取initrd.img 启动镜像。该文件中包含驱动模块等…

c语言用指针变量输入数组的长度,C语言之数组的基础练习题(指针变量做函数参数)...

1、交换两个变量的值&#xff1a;#include void swap(int *a,int *b){int tmp;tmp*a;*a*b;*btmp;}void main(){int x,y;int *p_x,*p_y;printf("请输入两个数&#xff1a;\n");scanf("%d",&x);scanf("%d",&y);p_x&x;p_y&y;swap(p…