Oracle中时间、数字、字符格式详解

数据库 Oracle
本文将用最简洁的语言为大家介绍Oracle中时间、数字、字符格式,希望对大家有所帮助。

本文面向想学习Oracle知识的各位数据库管理员,希望通过本文,让大家对于Oracle中时间、数字、字符格式有更深刻的理解。51CTO数据库也向您推荐《Oracle数据库开发应用指南》来帮助您更好的理解本文。

字符格式

Oracle中字符串的比较有两类

1.填补空格的语义比较

2.非填补空格的语义比较

填补空格的语义比较:

如果两个字符串有不同的长度,Oracle首先会在短的字符串那边末尾添加空格,直到两个字符串长度相等。

Oracle然后按字符顺序比较两个字符串的值,如果发现到不同的字符,则按字段顺序认定大小,如果没有发现不同字符,Oracle则认为两个字符串相等。这个规则意味着,如果只是尾号中有不同数目的空格,那么则认为两个字符串是相等的。如'a '='a'.

使用填补空格的语义比较,Oracle只针对char,nchar,字面量,或user函数返回的值。

非填补空格的语义比较:

Oracle通过字符顺序比较两个字符串的值。如果发现到字符值大的则大。如果两个字符串长度不同,则发现到字符值大的则大,否则长度大的则大,比如'b'>'ab','ab'>'a'.如果长度相等,并且各个位置字符相同,则认定为相等。

使用非填补空格的语义比较,Oracle针对varchar2和nvarchar2。

1.注意使用char,char是定长类型,不足长度末尾补空格,比较大小采用填补空格的语义比较

2.注意char与其他字符连接,如

  1. declare 
  2. char(3):='ab';  
  3. char(6):='ab';  
  4. begin 
  5. dbms_output.put_line(a||'c'); --ab c 其中ab和c之间有一个空格  
  6. dbms_output.put_line(b||'c'); --ab c 其中ab和c之间有4个空格  
  7. if a||'c' >b||'c' then 
  8. dbms_output.put_line(1); //成立,采用非语义比较。  
  9. end if;  
  10. end

3.在使用char的sql中,或表类型定义中,确定是定长的才使用,否则可能导致相关问题,如果有char的,比如要查询,如where charstring='abcd',后面的字面量最好和char长度一致

4.其实char 的效率和varchar2没有什么区别。tom测试过。

【编辑推荐】

  1. Oracle字段的转字符串实际操作方案
  2. Oracle数据库字符集进行转换的窍门
  3. Oracle字符集运用中易出现的问题分析
  4. Oracle数据库中的字符处理技巧
  5. 访问 Oracle 数据库的实例描述
责任编辑:彭凡 来源: ITPUB
相关推荐

2009-11-23 14:00:10

Oracle

2011-08-22 10:59:42

SQL Server日期时间格式转换字符串

2011-04-11 11:05:12

Oracle字符集

2011-05-26 13:36:40

Oracle数据库时间处理

2010-03-31 19:15:25

Oracle函数

2009-04-29 16:05:23

Oracle连接输出SQL

2010-03-29 13:19:10

OracleMulti

2010-09-14 14:32:02

sql server日

2011-09-05 19:02:45

MTK系统字符串

2016-05-12 15:51:08

前端开发字符编码

2010-05-06 09:19:03

Oracle表

2010-04-21 13:21:24

Oracle时间

2011-04-11 14:45:15

Oracle表系统时间

2022-06-26 08:39:19

Spring容器字段格式化

2010-04-30 14:47:56

Oracle表

2024-09-09 11:26:36

C#数字格式化

2011-05-19 13:25:14

Oracle数据库

2024-03-06 08:41:14

Python字符串格式化工具

2010-11-18 11:08:30

oracle授权语句

2010-11-15 11:58:02

Oracle物理结构
点赞
收藏

51CTO技术栈公众号