首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

PL/SQL 集合的方法

PL/SQL中提供了常用的三种集合联合数组、嵌套表、变长数组,而对于这几个集合类型中元素的操作,PL/SQL提供了相应的函数或过程来操 纵数组中的元素或下标。这些函数或过程称为集合方法。一个集合方法就是一个内置于集合中并且能够操作集合的函数或过程,可以通过点标志 来调用。本文主要描述如何操作这些方法。 一、集合类型提供的方法与调用方式 1、集合的方法与调用方式     EXISTS         函数EXISTS(n)在第n个元素存在的情况下会返回TRUE,否则返回FALSE。             通常使用EXISTS和DELETE来维护嵌套表。其中EXISTS还可以防止引用不存在的元素,避免发生异常。         当下标越界时,EXISTS会返回FALSE,而不是抛出SUBSCRIPT_OUTSIDE_LIMIT异常。     COUNT         COUNT能够返回集合所包含的元素个数,对于大小不确定的情形则COUNT非常有用。         可以在任何可以使用整数表达式的地方使用COUNT函数,如作为for循环的上限。         计算元素个数时,被删除的元素不会被count所统计。         对于变长数组来说,COUNT值与LAST值恒等。         对于嵌套表来说,正常情况下COUNT值会和LAST值相等。但是,当我们从嵌套表中间删除一个元素,COUNT值就会比LAST值小。     LIMIT         用于检测集合的最大容量         由于嵌套表和关联数组都没有上界限制,所以LIMIT总会返回NULL。         对于变长数组,LIMIT会返回它所能容纳元素的个数最大值,该值是在变长数组声明时指定的,并可用TRIM和EXTEND方法调整。     FIRST,LAST         FIRST和LAST会返回集合中第一个和最后一个元素在集合中的下标索引值。         对于使用VARCHAR2类型作为键的关联数组来说,会分别返回最低和最高的键值;键值的高低顺序是基于字符串中字符的二进制值。         但是,如果初始化参数NLS_COMP被设置成ANSI的话,键值的高低顺序就受初始化参数NLS_SORT所影响了。         空集合的FIRST和LAST方法总是返回NULL。只有一个元素的集合,FIRST和LAST会返回相同的索引值。         对于变长数组,FIRST恒等于1,LAST恒等于COUNT。         对于嵌套表,FIRST通常返回1,如果删除第一个元素,则FIRST的值大于1,如果删除中间的一个元素,此时LAST就会比COUNT大。         在遍历元素时,FIRST和LAST都会忽略被删除的元素。     PRIOR,NEXT,         PRIOR(n)会返回集合中索引为n的元素的前驱索引值;NEXT(n)会返回集合中索引为n的元素的后继索引值。         如果n没有前驱或后继,PRIOR(n)或NEXT(n)就会返回NULL。         对于使用VARCHAR2作为键的关联数组来说,它们会分别返回最低和最高的键值;键值的高低顺序是基于字符串中字符的二进制值。         PRIOR和NEXT不会从集合的一端到达集合的另一端,即最末尾元素的的next不会指向集合中的first。         在遍历元素时,PRIOR和NEXT都会忽略被删除的元素,即如果prior(3)之前的2被删除则指向1,如果1也被删除则返回null。     EXTEND         用于扩大嵌套表或变长数组的容量,该方法不能用于联合数组。         EXTEND有三种形式             EXTEND 在集合末端添加一个空元素             EXTEND(n) 在集合末端添加n个空元素             EXTEND(n,i) 把第i个元素拷贝n份,并添加到集合的末端         对嵌套表或变长数组添加了NOT NULL约束之后,不能使用EXTEND的前两种形式。         EXTEND操作的是集合内部大小,其中也包括被删除的元素。所以,在计算元素个数的时候,EXTEND也会把被删除的元素考虑在内。         对于使用DELETE方法操作的元素,PL/SQL会保留其占位符,后续可以重新利用。     TRIM         从集合的末尾删除一个(TRIM)或指定数量TRIM(n)的元素,PL/SQL对TRIM掉的元素不再保留占位符。         如果n值过大的话,TRIM(n)就会抛出SUBSCRIPT_BEYOND_COUNT异常。         通常,不要同时使用TRIM和DELETE方法。可把嵌套

03

Python 2.7.x 和 3.x 版

python现在很火,最近花了些时间去了解了一下,最初了解的是2.7.x版本,感觉,从书写上是很不习惯,少了一双大概号,取而代之的是缩进;然后跟kotlin和swift一样省去了每行的分号,象我们这种分号强迫症的人真心的不习惯;还有!True的条件改成not True、while后面可以跟else等等这些,真心不习惯啊!用2.7.x做了几天的测试,基本慢慢算有个了解了,也试着爬了些行业网的数据,感觉这个比PHP写爬虫方便很多。然后昨晚就在家里装了个3.X的版本,很悲催的发现,原来写的有很多的错误,万般无奈的检查之下,发现语句上是没什么问题,只是3.X版本不兼容部分的语句,例如最常用的print,raw_input都不一样了,今天花了些时间查一查,并总结了一下它们的区别。

03

Python学习笔记整理(十一)pyth

while语句,提供了编写通用循环的一种方法,而for语句是用来遍历序列对象内的元素,并对每个元素运行一个代码块。break,continue用在循环内,跳出整个循环或者跳出一次循环。 一、while循环 1、一般格式 格式:首行以及测试表达式,有一列或多列缩进语句的主体以及一个选用的else部分(控制权离开循环时而没有碰到break语句时会执行) python会一直计算开投的测试,然后执行循环主体内的语句,直到测试返回假值为止。 while <test>:     <statements1> else:     <statements2> 2、例子 >>> while True: ...  print "Type Ctrl+C to stop!" >>> while x:    ...     print x, ...     x=x[1:] ... diege iege ege ge e 注意 print末尾的逗号,会使所有输出都出现在同一行。 >>> a,b=0,10 >>> while a<b: ...     print a, ...     a+=1 ... 0 1 2 3 4 5 6 7 8 9 Python并没有其他语言中所谓的"do until”循环语句,不过我们可以在循环主体底部以一个测试和break来实现类似的功能。 while    True:     do something     if exitTest():break 3、对比shell的while语句 while 命令 do     命令1     命令2 done 在系统管理时常用与逐行读取一个文件并处理。 while read line do         echo $line done < /etc/rc.conf shell中还有一个类似while的循环until until 条件 do         命令1         命令2 done EG: IS_ROOT=`who |grep root` until [ "$IS_ROOT" ] do         echo 'root online'         sleep 2 done             二、 break continue pass和循环的else break     跳出最近所在的循环(跳出整个循环语句) continue     跳到最近所在循环的开头处(来到循环的首行,跳过本次循环) pass     什么事也不做,只是空占位语句 循环else块     只有当循环正常离开时才会执行(也就是没有碰到break语句) 1、一般循环格式 加入break和continue语句后,while循环的一般格式如下: while <test>:     <statements1>     if <test2>:break     if <test3>:continue     if <test4>:pass else:     <statements2> break和continue可以出现在while(或for)循环主体的任何地方,但通常会进一步嵌套在if语句中,根据某些条件来采取对应的操作。 2、列子 pass >>> while 1:pass ... pass可用于空类,有时有指的是"以后会填上”,只是暂时用于填充函数主体而已: >>> def func1(): ...     pass continue continue语句会立即跳到循环的顶端,开始下一次循环。 >>> while x: ...     x=x-1 ...     if  x%2!=0:continue ...     print x, ... 8 6 4 2 0 这个例子中,如果是奇数就返回循环顶部,不会打印.是偶数就打印。 这个下面这个结果一样 >>> while x:            ...     x=x-1           ...     if x%2==0:      ...             print x, ... 8 6 4 2 0 注意这两个例子的print位置,第一个print是属于while块的,测试不通过下执行,测试通过就回到循环顶端,第二个是属于if块的,只有测试通过才打印 >>> while x:            ...     x=x-1           ...     if x%2==0:      ...             print x, ...break break语句会

04

Python学习笔记整理(七)Pytho

一、元组介绍 元组(tuple)是无法修改的其他对象的结合.元组由简单的对象构成,元组与列表类似,不过元组不能在原处修改。通常写成圆括号中的一系列项。 1、元组的属性 *任意对象的有序集合 与字符串和列表类似,元组是一个位置有序的对象集合。与列表相同,可以嵌入任何类别的对象到其中,可以嵌套元组,列表,字典。 *通过偏移存取 同字符串,列表一样,在元组中的元素通过偏移来访问。支持所有基于偏移的操作,如果索引和分片 *属于不可变序列类型 类似于字符串,元组不可变,不支持在原处修改。与字符串和列表类似,元组有序列. 注意:元组的不可变性只使用与元组本身顶层而非其内容,元组的内部的列表,字典可以像往常那样修改。 *对象引用的数组 与列表类似,元组最好被认为是对象引用的数组。元组存储指向其他对象的存取点(引用),并且对元组进行索引操作的速度相对较快。 2、常见的元组操作 运算        解释 ()        空元组 t1=(0,)        单个元组的元组(非表达式) t2=(0,'A',1.3,4) 四个元素的元组 t2=0,'A',1.3,4  四个元素的元组 t3=(1,('A','B'))  嵌套元组 t4=(1,('A', 'B'),[4,5,6],{'name':'diege','age':18})    元组嵌套元组,列表,字典 t1[i]        索引 t1[i][j]    嵌套的索引 t1[i:j]        分片 len(t1)        长度,每一个元素算一个,不过元素是列表还是字典 len(t4)+len(t4[1])+len(t4[2])+len(t4[3]) t1+t2        合并 t2*3        重复 for x in t1:    迭代 'diege' i t2    成员关系 二、实际应用中的元组 1、元组的特殊语法,逗号和圆括号 >>> x=(40) >>> x 40 >>> x=(40,) >>> x (40,) 在不引起语法冲突的情况下,python允许忽略元组的圆括号,仅当元组做为文字传递给函数调用(圆括号很重要)以及当元组在print语句中列出(逗号很重要)的特殊情况时,圆括号才是必不可少的。 2、转换以及不可变性 除了常量语法不同外,元组的操作和字符串以及列表是一致的,值得注意的区别在于+ *以及分片操作应用于元组后将返回新的元组。并且元组不提供字符串,列表,字典中的方法。例如像对元组进行排序,通常先得将它转换为列表才能获得使用排序方法调用的权限将它变成一个可变的对象。 >>> T=('cc','aa','dd','bb') >>> temp=list(T) >>> temp.sort() >>> temp ['aa', 'bb', 'cc', 'dd'] >>> T=tuple(temp) >>> T ('aa', 'bb', 'cc', 'dd') 注意:元组的不可变性只使用与元组本身顶层而非其内容,元组的内部的列表,字典可以像往常那样修改。 >>> T=('a',[8,9],3.14) >>> T[1]=10 Traceback (most recent call last):   File "<stdin>", line 1, in <module> TypeError: 'tuple' object does not support item assignment >>> T[1][1]=10 >>> T ('a', [8, 10], 3.14) 3、为什么有了列表还要元组? Python的创造者,提到过把元组看作是简单的对象组合,把列表看成是随时间改变的数据结构。最佳答案似乎是元组的不可改变性提供了某种完整性,保证了数据的完整性。列表是定序集合的选择工具,可能需要进行修改。而元组能够处理其他固定关系的情况。 三、文件介绍 文件这个主要内置对象类型提供了一种可以存取Python程序内部文件的方法。 内置open函数会创建一个Python文件对象,可以作为计算机上的一个文件连接,在调用open之后,可以通过调用返回文件对象的方法来读写相关外部文件。文件可以通过调用open或file来打开。open通常比file更常用,因为file几乎都是为面向对象程序设计量身打造的。文件对象只是常见文件处理任务输出模块。多数文件方法都是执行外部文件的相关文件对象的输如输出有关,但其他文件方法可让查找文件中新位置,刷新输出缓冲等。 1、打开文件 处理模式没没有指定则默认为'r'。代表输入打开文件。'w'代表输出生成并打开文件,'a'代表为在文件尾部追加内容而打开文件。 "+"意味着同时为输入输出打开文件(也就是

03
领券