原创作品。从 “深蓝blog” 博客,欢迎转载,请务必注明转载的来源。权法律责任。

深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/39966251

【格式】

截取函数。能够实现提取字符串中指定的字符数

substr( string, start_position, [ length ] )

string:源字符串

start_position:提取的位置,字符串中第一个位置始终为1

[ length ]:提取的字符数。假设省略,substr将返回整个字符串

【实验】

目标:

    体会substr函数的使用方法

实验思路:

    实现将某列上指定字符位数的数据插入到指定的列上

模拟现场需求:

    设想略微复杂一下。我们假定须要将ename列的内容更改为ename1列的内容。但此时ename1列的字段长度超过了ename列的字段要求的最大长度,经过查看发现出现ename1列字段超出ename列字段长度的原因是ename1列数据类型为char(15),并且实际有效数据长度不到7个字符。所以仅仅须要将ename1列的前7位字符所有提取出来插入到ename列就可以。这也说明对于定长char类型,当输入字符不足定长时是会用空格进行补位的。

说明:

    这样的实验想法的出现,事实上是映射了实际生产需求中的一个样例。在实际生产环境上。要实现把一个用户的信息某一列的数据抽取到另外一个用户上,但因为两者列的数据类型不同,存在空格致使字段长度超过了另外一个用户要求该列字段的长度,而两者不能够更改数据类型。可是有效的字段数是都符合这两个列的,因此想到使用substr来完毕这个操作。

SQL> create table hyl as select * from emp where 1=2;
--创建实验表
Table created SQL> select * from hyl;
--查询实验表,眼下数据为空
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------ SQL> alter table hyl add(ename1 char(15));
--向实验表中加入实验列ename1,用于模拟长字符字段
Table altered SQL> insert into hyl(ename1) select emp.ename as ename1 from emp;
--将emp表的ename列数据以定长字段的数据类型插入到了实验表hyl的ename1列上,此时ename1字段长度为15
14 rows inserted SQL> select * from hyl;
--查看插入到ename1列上的数据
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ENAME1
----- ---------- --------- ----- ----------- --------- --------- ------ ---------------
SMITH
ALLEN
WARD
JONES
MARTIN
BLAKE
CLARK
SCOTT
KING
TURNER
ADAMS
JAMES
FORD
MILLER
14 rows selected SQL> select count(1) from hyl t where length(t.ename1)=15;
--验证一下,ename1列字段超过10的数据行数
COUNT(1)
----------
14 SQL> desc hyl;
--查看hyl表的表结构,能够看到ename1列为char(15)。ename列为varchar2(10)
Name Type Nullable Default Comments
-------- ------------ -------- ------- --------
EMPNO NUMBER(4) Y
ENAME VARCHAR2(10) Y
JOB VARCHAR2(9) Y
MGR NUMBER(4) Y
HIREDATE DATE Y
SAL NUMBER(7,2) Y
COMM NUMBER(7,2) Y
DEPTNO NUMBER(2) Y
ENAME1 CHAR(15) Y SQL> update hyl t set t.ename=t.ename1;
--更新ename列为ename1上数据时。报错了例如以下,提示ename字段长度(10)小于ename1字段长度(15)。无法完毕数据的更新
update hyl t set t.ename=t.ename1
ORA-12899: value too large for column "SCOTT"."HYL"."ENAME" (actual: 15, maximum: 10) SQL> update hyl t set t.ename=substr(t.ename1,1,7);
--使用substr函数。仅仅把ename1列的前7个字符的内容更新到ename列上
14 rows updated SQL> select * from hyl;
--再次查看hyl表,发现ename列的数据已经成功更新为enam1列上的数据
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ENAME1
----- ---------- --------- ----- ----------- --------- --------- ------ ---------------
SMITH SMITH
ALLEN ALLEN
WARD WARD
JONES JONES
MARTIN MARTIN
BLAKE BLAKE
CLARK CLARK
SCOTT SCOTT
KING KING
TURNER TURNER
ADAMS ADAMS
JAMES JAMES
FORD FORD
MILLER MILLER
14 rows selected SQL> desc hyl;
--再次查看hyl表的数据结构。体会怎样将ename1列数据类型为char(15)中前7个字符插入到数据类型为varchar2(10)的ename列上去的
Name Type Nullable Default Comments
-------- ------------ -------- ------- --------
EMPNO NUMBER(4) Y
ENAME VARCHAR2(10) Y
JOB VARCHAR2(9) Y
MGR NUMBER(4) Y
HIREDATE DATE Y
SAL NUMBER(7,2) Y
COMM NUMBER(7,2) Y
DEPTNO NUMBER(2) Y
ENAME1 CHAR(15) Y

原创作品。出自 “深蓝的blog” 博客。欢迎转载,转载时请务必注明出处,否则追究版权法律责任。

深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/39966251

版权声明:本文博客原创文章,博客,未经同意,不得转载。

SQL_substr功能测试的更多相关文章

  1. 关于web端功能测试的测试方向

    一.功能测试 1.1链接测试 链接是web应用系统的一个很重要的特征,主要是用于页面之间切换跳转,指导用户去一些不知道地址的页面的主要手段,链接测试一般关注三点: 1)链接是否按照既定指示那样,确实链 ...

  2. 几何服务,cut功能测试

    关于几何服务 几何服务用于辅助应用程序执行各种几何计算,如缓冲区.简化.面积和长度计算以及投影.在 ArcGIS Server 管理器中启动几何服务之后,您才能够在应用程序开发过程中使用该服务. 问题 ...

  3. Web应用功能测试测试点

    做了几年的功能测试,也经手了好几个Web应用的项目,在做项目当中积累了一些经验.在这里我对通用一些功能模块的测试点做个记录,一来梳理一下测试用例设计的思路,以便加快相似项目的测试用例的设计,二来有利于 ...

  4. 44、NLP的其他分词功能测试

    1. 命名实体识别功能测试 @Test public void testNer(){ if (NER.create("ltp_data/ner.model")<0) { Sy ...

  5. soapui中文操作手册(八)----Web服务的功能测试案例

    现在,让我们来看看在一个TestCase的功能测试. 展开 Simple TestSuite并双击Simple Login and Logout w. Properties Steps. 正如你所看到 ...

  6. (转载)关于web端功能测试的测试方向

    一.功能测试 1.1链接测试 链接是web应用系统的一个很重要的特征,主要是用于页面之间切换跳转,指导用户去一些不知道地址的页面的主要手段,链接测试一般关注三点: 1)链接是否按照既定指示那样,确实链 ...

  7. QEMU/KVM功能测试

    最近在对QEMU/KVM在HP服务器进行功能测试,项目刚刚启动,遇到不少问题,从Git上拿到最新的source build进行测试,在RHEL7.0a3 + Kernel version3.10 + ...

  8. 项目管理工具Redmine各功能测试

      Redmine 是一个开源的.基于Web的项目管理和缺陷跟踪工具.它用日历和甘特图辅助项目及进度可视化显示.同时它又支持多项目管理.Redmine是一个自由开放 源码软件解决方案,它提供集成的项目 ...

  9. API功能测试如何实施(转载自测试之道 微信公众号)

    什么是API 关于定义什么的,直接维基可得: API(Application Programming Interface,简称:API),又称为应用编程接口,就是软件系统不同组成部分衔接的约定.由于近 ...

随机推荐

  1. C#基础总结之Attribute

    Attribute是什么 Attribute的中文姓名 为什么我要拿一段文字来说Attribute的中文姓名呢?答案是:因为这很重要.正所谓“名”不正,则言不顺:另外重构手法中有一种很重要的方法叫重命 ...

  2. nginx 301跳转到带www域名方法rewrite(转)

    首先一.得在你的域名管理里面定义 test.com和www.test.com指向你的主机ip地址,我们可以使用nslookup命令测试:直接输入 nslookup test.com和nslookup ...

  3. IIS总提示输入用户名和密码

    解决办法: 第一步,在"运行"中输入"gpedit.msc"调出组策略设置. 找到计算机配置-管理模块-windows 组件-internet控制面板-安全页- ...

  4. Swift 的类、结构体、枚举等的构造过程Initialization(下)

    类的继承和构造过程 类里面的全部存储型属性--包含全部继承自父类的属性--都必须在构造过程中设置初始值. Swift 提供了两种类型的类构造器来确保全部类实例中存储型属性都能获得初始值,它们各自是指定 ...

  5. linux下用shell删除三天前或者三天内的文件

    说明:+n 大于 n, -n 小于 n, n 相等于 n. find / -amin -30 -ls # 查找在系统中最后30分钟访问的文件find / -atime -2 -ls # 查找在系统中最 ...

  6. HDU 4643 GSM 暑期多校联合训练第五场 1001

    点击打开链接 我就不说官方题解有多坑了 V图那么高端的玩意儿 被精度坑粗翔了 AC前 AC后 简直不敢相信 只能怪自己没注意题目For the distance d1 and d2, if fabs( ...

  7. bootstrap jQuery Ztree异步载入数据,check选择&amp;可加入、改动、删除节点

    效果图: 一.下载zTree插件 地址:http://www.ztree.me 二.html代码 <link href="../Scripts/zTree/css/zTreeStyle ...

  8. ThinkPHP的全部配置选项

    return array( /* Dispatch设置 */ 'DISPATCH_ON' => true, // 是否启用Dispatcher // URL模式: 0 普通模式 1 PATHIN ...

  9. 泛型Binary Search Tree实现,And和STL map比较的经营业绩

    问题叙述性说明: 1.binary search tree它是一种二进制树的.对于key值.比当前节点左孩子少大于右子. 2.binary search tree不是自平衡树.所以,当插入数据不是非常 ...

  10. android中的返回键与Activity

          我在做应用时遇到一个问题.就是在启动主页面时须要预先载入一些数据.我是在一个载入页中处理完这些数据然后再转到主页面.但当我在主页面中按返回键时,系统会返回载入页面.我不希望载入页在使用完之 ...