`
xls
  • 浏览: 110308 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

PL/SQL的高级查询

    博客分类:
  • SQL
 
阅读更多

PL/SQL的高级查询

1 With子句

1.1 学习目标

掌握with子句用法,并且了解with子句能够提高查询效率的原因。

1.2 With子句要点

1. with子句的返回结果存到用户的临时表空间中,只做一次查询,反复使用提高效率。

2. 如果定义了with子句,而在查询中不使用,那么会报ora-32035 错误:未引用在with子句中定义的查询名。

3. 前面的with子句定义的查询在后面的with子句中可以使用。但是一个with子句内部不能

嵌套with子句。

4. 当一个查询块名字和一个表名或其他的对象相同时,解析器从内向外搜索,优先使用子查询块名字。

5. with查询的结果列有别名,引用的时候必须使用别名或*

6. with有可能影响执行计划。

1.3 with子句语法

With alias_name as (select1), --asselect中的括号都不能省略

alias_name2 as (select2),--后面的没有with,逗号分割,同一个主查询同级别地方,with

查询只能定义一次

alias_namen as (select n) –与下面的实际查询之间没有逗号

Select ….

1.4 with使用例子:

1. 最简单的使用方法:

如查询部门名称包含“A”的所有员工信息

--with clause

with a as

(select deptno from dept where dname like '%A%')

select * from emp where deptno in (select * from a);

with a as

(select deptno from dept where dname like '%A%'),--a结果集

a2 as(select * from a where deptno>20)--a1结果集直接从a中筛选

select * from emp where deptno in (select * from a2);

2. 多层同级只能用一个with,并且后面的结果集可以使用前面的结果集:

查询部门名称包含“A”并且部门编号大于20的所有员工信息

with a as

(select deptno from dept where dname like '%A%'),--a结果集

a2 as(select * from a where deptno>20)--a1结果集直接从a中筛选

select * from emp where deptno in (select * from a2);

3. 不同级查询可以使用多个with

查询部门名称包含“A”并且部门编号大于20的所有员工信息的另外一种实现方式如下

with a as

(select deptno from dept where dname like '%A%')--a结果集

select * from emp where deptno in (--括号内层作为子查询,为第二级

with a2 as(select * from a where deptno>20)--a1结果集直接从a中筛选

select * from a2

);

1.5 使用场景

那什么情况下能使用到with子句呢?以下我就举几个简单的例子,简单的说明以下:

1. 我想测试一句sql,而我不想专门建立一个测试表:

我想测试成绩大于90的学生,我不想建立学生表,可以用到with子句

with stu as(

select '张娜' sname,99 score from dual union

select '王杰' ,35 from dual union

select '宋丽' ,85 from dual union

select '陈晓' ,73 from dual union

select '李元' ,100 from dual

)--with 组成一个临时的结果集,存放在用户的临时表空间

select * from stu where score>90

2. 当一个sql重复用到某个相同的结果集作为子查询:

--查询销售部工资>1500或者销售部工资小于1000的员工

select * from emp where deptno=(select deptno from dept where dname ='SALES') and sal >1500

union all

select * from emp where deptno=(select deptno from dept where dname ='SALES') and sal <1000

--以上sql select deptno from dept where dname ='SALES'需要执行两次,影响效率

--可以使用with优化一下

with salno as(select deptno from dept where dname ='SALES')

select * from emp where deptno=(select * from salno) and sal >1500

union all

select * from emp where deptno=(select * from salno) and sal <1000

2 集合操作

2.1 学习目标

掌握union,union all,minus,intersect的使用,能够描述集合运算,了解内部运行原理。

2.2 要点

Union all 效率一般比union高。Union all内部不做排序工作,也不做剔除

重复行工作,而union则做这个工作。所以当数据量比较大的时候,能用union all的时候尽量用union all。除了union all 默认不做排序和剔除重复行的操作外,

union,minus,intersect默认按第1个查询结果的第1列进行升序排列,并且

不包含重复行。

2.3 语法

select resource 1

Union/union all/minus/intersect

select resource 2

Union/union all/minus/intersect

select resource 3

……….

其中查询结果集的各个字段的类型能够互相兼容,并且总的结果集字段名与第一个结果集相同。

2.4 使用案例

数据准备:

create table t1 as select rownum rn from dual connect by rownum<7;

create table t2 as select rownum+3 rn from dual connect by rownum<7;

1. 查询t1t2表的所有记录,不去除重复。

2. 查询t1t2表的所有记录,去除重复。

3. 查询t1t2表都存在的记录

4. 查询t1表存在,t2表不存在的记录

5. 排序操作:

6. 除了union all其他的全部会在总的结果集中剔除重复,例如:

insert into t1 values(1);

commit;

现在t1表中有两条相同的记录,其rn的值为1

在进行集合运算时重复的记录被剔除:

2.5 使用场景

当要对多个结果集进行集合操作时,可是使用集合操作。

3 casedecode

3.1 学习目标

会使用case表达式和decode函数,理解各个参数和返回值的含义。

3.2 要点

Case表达式:

1. When后面的表达式类型应该全部保持一致,返回值类型也必须保持一致,或者能够进行隐式转换。

2. case 表达式 when 值,如果值是null,就算表达式也是null,结果也是返回false。也就是case 后面的表达式如果值为null,不会与when null 匹配,只会与else 匹配。

Decode函数的使用方法与case when相似,但是decode只能用等号匹配。

3.3 语法

Case表达式第一种:

case exp when comexp then returnvalue

..when comexp then returnvalue

Else

Returnvalue

End

Case表达式第二种:

case when Boolean then returnvalue

..when Boolean then return value

Else

Returnvalue

End

Decode函数:

decode(exp,

value1,res1,

value2,res2,.,

valuen resn,

elsevalue)

3.4 使用案例

Case 第一种用法:

Case 第二种用法:

Decode用法:

上文提到过null,碰到null的时候要注意,比如:

这种情况可以这样处理:

如果用decode函数:

3.5 使用场景

当我们的sql要求根据不同的条件返回不同的值时,可以使用。

4 existsinnot existsnot in

4.1 学习目标

掌握existsin的、not existsnot in的用法,了解其内部的执行顺序 与执行原理,知道什么情况下用exists,什么情况下用in

4.2 要点

1. Exists 用于只能用于子查询,可以替代in,若匹配到结果,则退出内部

查询,并将条件标志为true,传回全部结果资料。

2. 若子查询结果集比较小,优先使用in,若外层查询比子查询小,优先使用exists。因为若用in,则oracle 会优先查询子查询,然后匹配外层查询,若使用exists,则oracle 会优先查询外层表,然后再与内层表匹配。最优化匹配原则,拿最小记录匹配大记录。

4.3 语法

InSelect select_fields from table_name where field_name in(select clause)

ExistsSelect select_fields from table_name exists (select clause)

4.4 使用案例

查询员工部门编号在部门表中存在的员工记录:

以上语句可以用Exist替换:

另外not innot exists在某些情况下也可以相互转换,但是要注意一点,not in中的子查询返回的结果集包含null值的时候,查询会失效。例如我想查询对应员工记录数为0的部门。如下:

not exists:

以上语句不能用not in替换:

查询失效无记录返回。注意这并不是oraclebug,因为在oraclenull不表示空,而是表示未知,当使用not in的时候,如果子查询返回的结果集中包含null值,我们并不知道外层查询的记录在不在子查询返回的结果集之内,所以无记录返回。虽然这样,但是并不表示not innot exists是完全不可以转换的,比如子查询所选的字段在对应的表中没有null值,这时not innot exists是可以相互转换的。或者在某些情况下内层子查询加上field_name is not null限制条件也是可以的。

4.5 使用场景

当内层查询返回的结果集较小时,用in 或者not in效率较高。当内层子查询返回的结果集比较大时,用exists或者not exists执行的效率较高。

5 行列互换

5.1 学习目标

掌握列转行技术和常用的行专列技术。

5.2 要点

行专列的情况有多种,不同的情况侧重点也不一样。

5.3 语法

5.4 使用案例

1. 列转行

第一种方法:需要用到union或者union all

第二种方法:用到model

2. 行专列,如我有escore表用来记录每个学生每个科目的成绩,如下:

如果我想将每个学生的成绩统计在一行上,如:

3 语文 11 数学 55 英语 66

则我可以使用如下sql:

这个sql表面上看没什么问题,但是仔细看一下三个结果集esysss,他们来源于同一个表,而且查询方法也类似,都是根据type的值去筛选的,这样就会对escore表查询三遍,严重影响查询速率,那这个sql我们如何去优化呢!

首先在你的脑海里面要有一种思路,根据需求,原先每个学生成绩有多行记录,现在要显示到一行上,那一般情况下我们是需要根据学生分组的。所以group by sid 这个是一定要有的,既然分组那我们可是使用oracle的聚合函数去求其他行的数据。至于科目字段目前都是已知的,也就是第2,4,6列显示的分别是英语、语文、数学这几个字,是常量,我们不用去考虑,那剩下的也就是最关键的,我们去求三科的成绩就可以了。
让我们再看一下escore表,当指针移到某一行数据时,当type=e时,我们就取到score,加到第三列上,那第五列和第七列就加0,也就是sum(decode(type,’e’,score,0)),其他列类似,这样group by时用到的聚合函数还有decode结合在一起使用,就可以完成我们的要求了,sql写出来时这样的:

3. 字符串组合的多行转一列,例如我有一张测试表如下:

我想根据id分组,将每一行的name连接起来,如下图是我想要的结果:

这种行转列不是真正意义的行转列,是多行数据的值拼接后显示到一列上,那这种情况怎么处理呢,首先分析一下:多行id相同的值转换成一行,一般情况下需要用到group by,但是对于字符串,oracle中没有一个聚合函数适合用到此处的字符串连接,那该怎么办呢?

oracle中,有sys_connect_by_path(field_name,concat_value)函数,可以通过connect by来依次连接每一行的数据,connect by 的语法是这样的:

start with field1=1--以当前表达式返回true的行开始

connect by prior field2=field3--通过当前行查找下一行,也就是说某一行数据的field3字段等于当前行的field2,那就把这行数据作为下一行

有了这个思路,我们就可以用connect by 通过使用sys_connect_by_path(field_name,concat_value)这个函数,并且根据id分组,将字符串连接在一起,然后通过max聚合函数,选出每组最长的字符转就可以了,那剩下的也就是最关键的问题就是我怎样去使用connect by,通过当前行找到下一行呢?充分发散一下你的思维,看一下如下结果集:

那我下一步用如下思路使用connect by将所要的结果查询上来:

start with lg is null--lgnull的行作为起始行

connect by prior rn=lg and prior id=id --当前行与其他行比较,满足这个条件的就作为下一行数据

总的查询结果如下:

其实怎么使用connect by 方法很多,例如如下sql也能完成:

5.5 使用场景

当开发过程中,需要我们将多列转换成多行或者将多行转换成多列的时候,就需要用到行列转换,要根据不同的情况确定不同的结果方案,典型的行列转换就这几种,还有一种比较复杂的是不定不定行专列,不定行转列需要用到oraclepackage,在次先不做讲解。

6 merge into

6.1 学习目标

掌握merge into,学会使用merger into批量处理数据。

6.2 要点

1. MERGE语句是Oracle9i新增的语法,用来合并UPDATEINSERT语句。

2. MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT

3. 这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERTUPDATE

6.3 语法

MERGE [INTO [schema .] table [t_alias]
USING [schema .] { table | view | subquery } [t_alias]
ON ( condition )
WHEN MATCHED THEN merge_update_clause
WHEN NOT MATCHED THEN merge_insert_clause;

6.4 使用案例

1. 基于escore表创建escore2表,英语成绩每个同学加上5分的课时分,新增政治成绩,如下:

create table escore2 as select sid,type,score+5 score from escore where type='e'

insert into escore2 values(1,'z',31);

insert into escore2 values(2,'z',45);

insert into escore2 values(3,'z',66);

insert into escore2 values(4,'z',76);

commit;

根据escore2表更新escore表,根据sidtype匹配,对于已经存在的记录进行更新操作,对于不存在的记录进行插入操作。

merge into escore t

using escore2 t2--此处可以是表、视图和查询结果集

on (t.sid=t2.sid and t.type=t2.type)--匹配条件,需要加括号

when matched then

update set t.score=nvl(t2.score,decode(t.type,'e',5,0))--根据匹配条件,更新escore

when not matched then

insert values(t2.sid,t2.type,t2.score)--无匹配条件的记录,插入新记录

执行merge以后的escore表如下:

注意update的时候不能修改匹配的连接字段,否则就会报错。

6.5 使用场景

当要依赖别的表、视图或者结果集批量修改和插入目标表数据时,可以使用此方法,运行速率快,而且简单。

7 group by高级特性

7.1 学习目标

学会使用group by语句,学会使用group by输出小计、合计。

7.2 要点

1. select 语句中可以使用group by 子句将行划分成较小的组,然后,使用聚合函数返回每一个组的汇总信息。

2. 可以使用having子句限制返回的结果集。

3. 在带有group by 子句的查询语句中,在select 列表中指定的列要么是group by 子句中指定的列,要么包含聚组函数语法。

4. 使用rollup操作符产生subtotal(小计)的值,cube 操作符产生cross-tabulation(列联交叉表)的值。

5. 使用grouping函数标识通过rollupcube 建立的行的值。

6. 使用grouping sets产生一个single result set(结果集)

7. 使用grouping_idgroup_id函数。

7.3 使用案例

1. 查询部门员工的最高工资大于1500的部门,如下:

相信这样的案例大家已经很熟悉了,以下讲解一下group by的高级特性。

2. Rollup可以返回合计,例如:

rollup(a,b) 包括:(a,b)(a)()的合计

rollup(a,b,c) 包括:(a,b,c)(a,b)(a)()的合计

我想按班级和学生分组,查询班级下学生的总分,并且做一下小计,使用以上的escore表,并且新建学生班级的关系表如下:

create table refcs as

select 1 cid,1 sid from dual

union all select 1,2 from dual

union all select 2,1 from dual

union all select 2,2 from dual

则查询的sql如下,红色区域是每个班级的总分合适,蓝色区域是所有的总分合计:

3. cube可以返回交叉的合计,例如:

cube(a,b) 包括:(a,b)(a)(b)()
cube(a,b,c)
包括:(a,b,c)(a,b)(a,c)(b,c)(a)(b)(c)()

rollup相比,多了灰色区域,灰色区域是对分组的第二个字段sid的小计,用来统计每个学生的总分数,但在此是没有多大意义的,因为学生和班级是1->n的关系,统计每个学生的总分数和统计每个班级下每个学生的总分数没有区别。

4. GROUPING函数可以接受一列,返回0或者1。如果列值为空,那么GROUPING()返回1;如果列值非空,那么返回0GROUPING只能在使用ROLLUPCUBE的查询中使用。当需要在返回空值的地方显示某个值时,GROUPING()就非常有用。

看如下sql,红色区域和蓝色区域的grouping参数字段是null,因此grouping字段返回1,非null时返回0

但是返回01似乎没有多大意义,通常返回一些有意义的字符串可读性能好一些,如下:

其实你可以再优化一下,让第一行只显示“总计”两个字。

5. Grouping sets:以上用GROUP BY ROLLUPGROUP BY CUBE替代GROUP BY,来计算高级的统计,不过它们会生成所有可能的总数,而你可能不需要全部总数,可以用GROUP BY GROUPING SETS来代替GROUP BY CUBE。你可以应用来指定你感兴趣的总数组合。因为它不必计算它不需要集合(也不会产生太多结果),所以对SQL引擎来说更为高效。例如:

在图中我已经用不同颜色的边框和箭头指明某行数据来源于grouping sets之后的哪些集合。

7.4 使用场景

分组时常用。

8 分析函数

8.1 学习目标

掌握分析函数的使用,能用分析函数解决复杂查询等问题。

8.2 要点

1. 分析函数可分为四类:等级函数(ranking),聚合函数(aggregate),行比较函数(row comparison),统计函数(statistical)

2.

8.3 语法

函数名(参数)over(partition by …order by…windows clause)

8.4 使用案例

1. Row_numberrankdense_rank属于等级函数,例如,我想根据部分分区,查询部门内部员工公司的排名,看一下用这三个等级函数会有什么区别:

我们发现三个函数都是返回分区排序后的序号,不同之处在于排序字段相同时,row_number是从1n连续不跳号的,rank是给予值相同的两行相同的序号,而且跳号,dense_rank也是给予值相同的两行同样的序号,但是不跳号。

2. 常用分析函数:看一下以下一个sql中包含了多个常用的分析函数,图中需要注意的地方我已经圈出来并且标明了:

常用的分析函数还有lagleadpercent_rankPERCENTILE_COUNT等,大家可以自己回去研究一下。

3. Firstlast返回通过dense_rank排序后的第一个或者最后一个。例如我想查询员工的最小工资最小的部门和员工的最大工资最大的部门:

4. Windows子句,用来指明分析函数的计算窗口,语法如下:

窗口的划分方式有rangerows两种,Rows 表示物理偏移量,range表示逻辑偏移量。用rows range划分窗口,按照起点在上,终点在下的原则(如果违反这个原则,则分析函数的计算结果为null,对窗口中的每一行应用分析函数计算结果。如果我想取:当前sal-500到当前sal为一个窗口,并按照窗口来计算工资总和,可以用如下sal来实现:

5. 分析函数与group by结合,进行topN查询,例如我想查询总工资前三名的部门,如下:

8.5 使用场景

逻辑比较复杂的查询,往往需要用到分析函数。

9 rownum

9.1 学习目标

理解oracle内部rownum的原理,会使用rownum进行top-N查询和其他范围查询。

9.2 要点

1. rownum where 在同一层查询中,where 条件之后使用rownum 比较,只能使用<=,<,!=,<>,不能使用>,>=(>=1是可以的,和不加效果一样),=(使用=,只能是where rownum=1才可以)。否则不返回任何数据。如果使用!=<>,那么只是返回前n-1行,其他按照rownum工作原理推算。

2. rownum order by 在一个语句级别中(同一层)使用的时候.看这个查询的数据是否从索引中获取(或者根据索引先得到rowid然后定位行)的,如果不是,那么就是先查询出来,每行标上rownum,然后order by 将结果重新排序,那么rownum的顺序是乱的。如果排序的数据是从索引中查询的,这样结果有序。这取决于执行计划,执行计划又和oracle优化器相关。

3. 在执行语句时,有关rownum执行的顺序是这样的:

1) 执行查询操作,初始化rownum值为1

2) 指针指向第一行,将该行的rownum标记为1

3) 进行where条件匹配,如果where条件返回false,则抛弃行,返回true,则返回该行,并且将rownum值自增1

4) Oracle获取下一行,将该行的rownum标记为当前rownum值。

5) 返回第三步。

9.3 语法

Rownum可以用在where条件中,如:

Select * from emp where rownum<5;

9.4 使用案例

1. Top-N查询:

2. 查询中间几行:

看一下oracle执行的原理,当指针移动到第一行的时候,rownum=1rownum between 3 and 5返回false,第一行被抛弃,指针指向第二行,此时rownum还是为1,第二行也被抛弃,以此类推,无结果返回。这种情况可以使用子查询,先把rownum最为rn字段缓存到结果集里面,然后对结果集进行筛选:

3. 上述查询其实存在隐患,不知道大家注意没有?子查询中select rownum rn,empno from emp order by empnooracle的执行顺序是先取到结果集,标记上rownum,然后进行排序,这样rownum的序号不一定是排序后的序号,所以取到的数据可能不是我想要的。那此处为什么我能取到正确的数据呢?这取决与执行计划,在emp表中,empno作为表的主键,也就是唯一索引,在取得子查询结果集得时候,oracle是根据索引读取数据的,而索引一般是在oracle的内存中,并且索引是有序的,优化器选择索引的方式访问emp表,所以oracle读取数据的同时为当前行标记上rownum,所以rownum顺序不会错乱。如果我是通过ename排序取3-8行,empename上并没有建立索引,所以读取的数据时错乱的,如下:

此时再用外层查询取得rn between 3 and 8,就会取得错误的数据。

此时能够保证数据是正确的。有关案例2order byrownum要慎用,因为即使在相关字段上有索引,oracle的优化器也不一定会选择索引访问数据,这根表的状态和其他很多原因都有关系,有关索引和执行计划的相关知识,这里不做讲解,将会在以后的课程中放在oracle优化的科目中进行讲解。

9.5 使用场景

在进行top-N查询或者取中间数据时可能用到。

10 rowid

10.1 学习目标

了解rowid的组成部分,会使用rowid进行删除重复行等查询。

10.2 要点

1. rowid的是基于64位编码的18个字符,由数据对象编号+文件编号+块编号+行编号组成(数据对象编号(6) +文件编号(3) +块编号(6)+行编号(3)=18位)。

10.3 语法

10.4 使用案例

1. Rowid经常用于删除重复行,如我用如下语句加入escore2两条重复数据,如下:

insert into escore2 select * from escore2 where sid=1;

commit;

很显然,圈出的数据为重复数据,如下我可以用rowid来删除重复数据:

delete from escore2 where rowid not in(

select min(rowid) from escore2 group by sid ,type,score

);

commit;

再来看一下escore2表,重复数据没有了:

2. 分页,例如我想取escore2表的第4-6条数据,也就是上图456行,如下:

10.5 使用场景

Rowid可用于删除重复数据或者分页,还可以用于其他的需要唯一标识行的sql

11 Dade的使用

11.1 学习目标

掌握date数据类型,会使用date类型,并且掌握date类型的常用函数。

11.2 要点

1. 一些常用的数据格式要牢记,他们就像date对象的属性,当你要访问date对象的相应属性时,需要将这个属性作为参数传入,属性对应的值才能被返回,如:

1) YYYYYY 年的最后一位,两位或三位

2) Q 季度

3) MM 月份

4) Month 9个字符长度表示的月份名

5) WW 当年第几周

6) W 本月第几周

7) DDD 当年第几天

8) DD 当月第几天

9) D 周内第几天

10) DY 中文的星期几

11) HHHH12 12进制小时数 HH24 24小时制

例如今天是2011718日,星期一,执行如下sql看一下结果:

2. 一些常见函数的用法:

1) 对于to_dateto_char函数大家应该很熟悉了,这应该是oracle里面最常用的函数了,如下:

需要强调一点的是,oracle有默认的显示格式,对于这个格式的字符串,oracle是可以识别的,并且能通过隐式转换将其转换为date类型,如下sql(在命令行执行):

由以上结果的输出可以看出我当前数据库的时间匹配格式是18-JUL-11的,那oracle可以接收这种类型的字符串将其隐式转换为date类型,如下sql:

如下我修改了当前session的默认时间格式,则执行不报错,但是只在当前session有效:

2) Last_day(mydate),此函数返回mydate所在月份的最后一天。

3) Add_month(mydate,n),返回mydate推后n个月后的日期。

4) Months_between(date1,date2),返回date1date2间隔的月数。

5) Next_day(mydate,dayofweek),返回自mydate日期起,下一个dayofweek(星期几)的日期。

6) Trunc(mydate,格式字符串),返回对mydate截断到指定位置后的日期。Round(mydate,格式字符串),返回对mydate四舍五入到指定位置的字符串,如下sql:

11.3 使用场景

对于日期的计算需要用到日期函数,如:

1) 上个月末:trunc(sysdate,'mm')-1

2) 本月最后一秒:trunc(last_day(sysdate)+1,'dd')-1/24/60/60

3) 本月的天数:trunc(last_day(sysdate)+1)-trunc(sysdate,'mm')

12 字符串函数的使用

12.1 学习目标

掌握常用的字符串函数,能够用字符串函数解决相关问题。

12.2 要点

1. ascii(char):返回字符串首字符串的ASCII码值。Chr(n):返回ASCII码值n对应的字符。如下:

2. concat(str1,str2,…),返回str1str2……连接后的字符串。

3. initcap(str),返回每个单词首字母大写的字符串。

4. instr(char1,char2[,n[,m]]):用于取得子串在字符串中的位置,其中数字n为起始搜索位置,数字m为子串出现次数。如果数字n为负数,则从尾部开始搜索。数字m必须为正整数,并且nm的默认值为1

5. length(char):返回字符串的长度。如果字符串的类型为char,则其长度包括所有的后缀空格;如果charnull,则返回null

6. lower(char):用于将字符串转换为小写格式;upper(char):将字符串转换为大写格式。

7. lpad(char1,n,char2):用于在字符串char1的左端填充字符串char2,直至字符串总长度为nchar2的默认值为空格。如果char1长度大于n,则该函数返回char1左端的n个字符;rpad(char1,n,char2)用于在字符串char1的右端填充字符串char2,直至字符串总长度为nchar2的默认值为空格。如果char1长度大于n,则该函数返回char1左端的n个字符。

8. trim(char from string)用于从字符串的头部、尾部或两端截取特定字符;ltrim(char1[,set]):用于去掉字符串char1左端所包含的set中的任何字符。Oracle从左端第一个字符开始扫描,逐一去掉在set中出现的字符,当遇到不是set中出现的字符时终止,然后返回剩余结果;rtrim(char1[,set]):用于去掉字符串char1右端所包含的set中的任何字符。Oracle从右端第一个字符开始扫描,逐一去掉在set中出现的字符,当遇到不是set中出现的字符时终止,然后返回剩余结果。

9. replace(char,search_string[,replacement_string]):用于将字符串的子串替换为其他子串。如果search_stringnull,则返回原有字符串;如果replacement_stringnull,则会去掉指定子串。

分享到:
评论

相关推荐

    的最全韩顺平php入门到精通全套笔记.doc )

    【PHP入门】 PHP(Hypertext Preprocessor)是一种广泛使用的开源服务器端脚本语言,尤其适用于Web开发,能够嵌入HTML中。本篇笔记基于韩顺平老师的讲解,全面覆盖了从基础到精通的PHP知识体系。 1. **HTML基础** HTML,即超文本标记语言,用于创建网页内容。它包括各种标签来定义网页结构,如`<html>`、`<head>`、`<body>`等。HTML与CSS结合使用,可以实现页面样式控制。HTML5作为最新版本,引入了更多增强功能,如离线存储、拖放功能和媒体元素等。运行HTML有两种方式:本地运行(直接通过浏览器打开文件)和远程访问(通过HTTP协议在服务器上运行)。 2. **动态网页技术** 动态网页能够根据用户输入或服务器状态变化实时更新内容。PHP作为动态网页开发的重要技术之一,具有跨平台、安全性高、效率好、成本低、易于学习和丰富的开源社区支持等优点。PHP可以连接多种数据库,如MySQL,并在PHP4、PHP5和PHP6(及后续版本)中逐。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    花生好坏缺陷识别数据集,7262张图片,支持yolov7格式的标注,识别准确率在95.7%

    花生好坏缺陷识别数据集,7262张图片,支持yolov7格式的标注,识别准确率在95.7% 两种标签: Good,Bad 花生好坏缺陷识别数据集,7262张图片,支持yolo,coco json,pasical voc xml格式的标注,识别准确率在95.7% 详情查看地址:https://backend.blog.csdn.net/article/details/144983881

    总务科(基建办)2024年工作总结.doc

    总务科(基建办)2024年工作总结.doc

    基于springboot+vue的相亲网站(Java毕业设计,附源码,部署教程).zip

    该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:HTML + Vue.js 后端框架:Spring Boot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven

    广东省高清卫星地图全图

    广东省高清卫星地图全图

    智能聊天机器人在电商客服领域的应用研究与开发毕业设计报告

    本文聚焦智能聊天机器人于电商客服领域的应用,开篇点明研究背景,剖析电商发展促使客服需求暴增,传统客服乏力,智能机器人应运而生。接着详述电商客服发展脉络、现存痛点,如高峰拥堵、知识滞后、服务同质化等。核心技术涵盖自然语言处理、机器学习、知识图谱,系统采用微服务架构,各模块分工协作。开发流程包括精细调研、多元数据采集、模型选型调优等。创新应用体现于售前精准导购、沉浸式营销,售中订单跟踪、答疑,售后问题处理与回访。经量化指标与用户调研评估成效显著,虽有挑战,但未来借助新技术有望重塑电商服务生态,助力企业与消费者双赢。

    基于springboot+vue的人口老龄化社区服务与管理平台(Java毕业设计,附源码,部署教程).zip

    该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:HTML + Vue.js 后端框架:Spring Boot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven

    eap2025010741566905-1-1.pdf

    eap2025010741566905-1-1.pdf

    双馈风机MATLAB simulink模型 多个模型打包发送

    双馈风机MATLAB simulink模型 多个模型打包发送

    小熊汉字笔顺学习软件 v2.0

    给小孩找的,看着还不错,分享出来~

    基于springboot+vue的美容院管理系统(Java毕业设计,附源码,部署教程).zip

    该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:HTML + Vue.js 后端框架:Spring Boot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven

    bcolz-1.2.1-cp38-cp38-win-amd64.whl.rar

    bcolz-1.2.1-cp38-cp38-win-amd64.whl.rar

    自动驾驶技术中域控制单元(DCU)的核心作用与发展前景

    内容概要:本文详尽阐述了自动驾驶技术中的域控制单元(DCU)及其重要性。首先介绍了ADAS(高级驾驶辅助系统)和AD(自动驾驶)的区别和发展现状。接着讨论了域控制单元作为高级ECU,在自动驾驶系统中扮演的重要角色,包括高性能计算、高效的数据处理能力和与其他子系统的紧密配合。文中详细解释了DCU的构成元素——收发器、SoC、MCU和电源管理等模块的工作原理和技术细节,同时也探讨了市场趋势和技术发展趋势,如高集成度、智能化、低功耗等方面。最后展望了DCU在未来域集中式EE架构下的广阔应用前景。 适用人群:从事汽车工程、自动驾驶技术和嵌入式软件开发的专业技术人员,以及对此领域感兴趣的科研工作者。 使用场景及目标:①帮助开发者深入了解自动驾驶系统组成尤其是DCU的设计理念和技术特征;②指导相关领域的研究者把握当前行业发展动态和技术前沿。 其他说明:本文不仅深入浅出地讲解了专业知识,而且引用了一些作者个人感悟的文字,增加了可读性和启发性。

    Java与Python编程语言特性、应用场景及其学习选择

    内容概要:文章主要介绍了Java和Python这两种流行的编程语言之间的区别和联系。首先详细讲述了Java的基本特性,包括跨平台性、面向对象编程、类型安全、自动化内存管理和多线程支持等特点,并概述了其在企业级开发中的广泛应用。接着深入探讨了Python的特点,指出它的简明语法、灵活性以及丰富的生态体系,特别提到了其在数据分析、人工智能等前沿领域的优势。文中还比较了两者的应用场景和技术实现方式的不同之处。最后为初学者提出了基于个人职业发展目标来选择编程语言的建议。 适合人群:对编程有兴趣的学生、编程新手以及想要转换编程方向的技术人员。 使用场景及目标:有助于读者理解两种编程语言各自的优劣,便于在实际工作中或者个人兴趣发展中做出明智的选择。 其他说明:通过对比讲解,不仅展示了两种编程语言的共同点,还强调了它们各自独特的优势所在。这有助于加深读者对其本质特征的认识,从而更好地应对不同类型的编程任务和挑战。

    Java 飞机订票系统实训报告

    Java 飞机订票系统实训报告,有数据库

    easy-interceptor修改请求头和响应头.zip

    easy-interceptor修改请求头和响应头.zip

    Python身份证识别系统源码(精准度非常高).zip

    Python身份证识别系统源码(精准度非常高).zip,个人大三大作业设计项目、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 Python身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系统源码(精准度非常高).zipPython身份证识别系

    【电磁】基于matlab微带线中的电势和场分布【含Matlab源码 10949期】.zip

    Matlab领域上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    一个利用深度学习模型(LSTM 网络)对电商用户咨询文本进行意图分类的python源码

    功能:利用深度学习模型(LSTM 网络)对电商用户咨询文本进行意图分类,相比简单规则匹配,能处理更复杂、语义模糊的文本,精准识别用户需求。 技术要点:使用 TensorFlow 构建 LSTM 模型,包括文本预处理将文本数字化,Embedding 层将数字映射为向量,LSTM 层捕捉序列特征,Dense 层输出分类结果,通过训练优化模型参数,实现准确意图识别。

    国产银河麒麟V10和统信系统(linux)没有root用户的解决办法

    国产银河麒麟V10和统信系统(linux)没有root用户的解决办法。如何在没有root用户的情况下,开通和启用root用户

Global site tag (gtag.js) - Google Analytics