为兼容Oracle的数据类型,KingbaseES扩展了Oracle的NUMBERVARCHAR2CHAR(n)DATE类型。该措施使得移植Oracle的Create Table等DDL语句时,无需任何修改就能直接在KingbaseES环境中运行。

虽然扩展了oracle的字符类型,但是相同数据类型之间还是有有些区别:

数据类型 KingbaseES Oracle 
CHARACTER(n)

CHAR(n)

NCHAR(n)
char表示一个字符

Byte表示一个字节

默认为1

值域:10485760 char | byte。

值域:11g 默认值 1
CHAR=2000 byte|char
NCHAR=2000 byte
12c最大支持到32k(32767)

CHARACTER VARYING(n) NVARCHAR(n)

NVARCHAR2(n)

VARCHAR(n)

VARCHAR2(n)
值域:10485760 char | byte。

默认长度:可以不指定,默认没有限制。

值域:11g
VARCHAR2=4000 char|byte
NVARCHAR2=4000 byte
默认长度:VARCHAR2必须指定长度
12c最大支持到32k(32767)

下面通过一些例子来验证一下:

1、数据类型的最大长度

Oracle11g

char类型的最大长度是2000字节,varchar2是4000个字节。nchar,nvarchar2类型的最大长度根据数据集不同而不同。最终的byte数不能超过2000和4000。如字符集为AL16UTF16,则nchar的为2000/2=1000,而nvarchar2则为4000/2=2000

SQL> create table o_test1(name char(2001));

create table o_test1(name char(2001))
*
ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table o_test1(name char(2000)); Table created. SQL> create table o_test2(name varchar2(4001)); create table o_test2(name varchar2(4001))
*
ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table o_test2(name varchar2(4000)); Table created. SQL> create table o_table3(name nchar(1001)); create table o_table3(name nchar(1001))
*
ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table o_table3(name nchar(1000)); Table created. SQL> create table o_table4(name nvarchar2(2001)); create table o_table4(name nvarchar2(2001))
*
ERROR at line 1: ORA-00910: specified length too long for its datatype SQL> create table o_table4(name nvarchar2(2000)); Table created.

  

KingbaseES

理论最大值10485760

test=# create table k_test1(name char(10485761));
错误: 类型 char 的长度不能超过 10485760
第1行create table k_test1(name char(10485761));
^
test=# create table k_test1(name char(10485760));
CREATE TABLE test=# create table k_test2(name varchar(10485761));
错误: 类型 varchar 的长度不能超过 10485760
第1行create table k_test2(name varchar(10485761));
^
test=# create table k_test2(name varchar(10485760));
CREATE TABLE test=# create table k_test3(name varchar2(10485761));
错误: 类型 varchar 的长度不能超过 10485760
第1行create table k_test3(name varchar2(10485761));
^
test=# create table k_test3(name varchar2(10485760));
CREATE TABLE

2、char 默认长度

Oraclechar类型,不带字符数的时候,是1个字符(char(1)),而varchar2必须有字符数。nchar和nvarchar2分别与char,varchar2类似。

SQL> create table o_test1(name char, addr varchar);
create table o_test1(name char, addr varchar)
*
ERROR at line 1:
ORA-00906: missing left parenthesis SQL> create table o_test1(name char, addr varchar(5));
Table created. SQL> insert into o_test1 values('12','OK');
insert into o_test1 values('12','OK')
*
ERROR at line 1:
ORA-12899: value too large for column "SYS"."O_TEST1"."NAME" (actual: 2, maximum: 1) SQL> insert into o_test1 values('1','OK');
1 row created.

  

KingbaseES:

char类型,不带字符数的时候,也是默认一个字符(char(1)),而varchar不带字符数的时候,没有限制。

test=# create table k_test4(name char, addr varchar);
CREATE TABLE test=# insert into k_test4 values('12', '1234567890');
错误: 对于字符类型来说这个值太长了(1) test=# insert into k_test4 values('1', '1234567890');
INSERT 0 1

3、插入数据库的时候的,字符数超出最大长度部分的处理。

Oracle报错。

SQL> insert into o_test1 values('1','123456');
insert into o_test1 values('1','123456') ERROR at line 1:
ORA-12899: value too large for column "SYS"."O_TEST1"."ADDR" (actual: 6,maximum: 5) SQL> insert into o_test1 values('1','1234 ');
insert into o_test1 values('1','1234 ') ERROR at line 1:
ORA-12899: value too large for column "SYS"."O_TEST1"."ADDR" (actual: 6,maximum: 5)

  

KingbaseES:当超出部分是有效的字符的时候,报错。但是,当使用明确的类型转换为最大字符数的时候,截断为最大长度,不报错。

test=# create table k_test5(name char(2), addr varchar(5));
CREATE TABLE test=# insert into k_test5 values('123', '12345');
错误: 对于字符类型来说这个值太长了(2) test=# insert into k_test5 values('12 ', '12345');
错误: 对于字符类型来说这个值太长了(2) test=# insert into k_test5 values(102::char(2) , '12345');
INSERT 0 1 test=# select * from k_test5;
name | addr
------+-------
10 | 12345 (1 行记录)

  

参考文档:

[应用开发及迁移]Oracle至KingbaseESV8迁移最佳实践

字符类数据类型和oracle字符类型的区别的更多相关文章

  1. KingbaseES 时间类型数据和oracle时间类型的区别

    Oracle日期时间类型有两类,一类是日期时间类型,包括Date, Timestamp with time zone, Timestamp with local time zone.另一类是Inter ...

  2. oracle 插入数据之坑--------oracle字符类型varchar2一个中文占多少字节

    如果你误认为是两个字节,那就大错特错了 Oracle 一个中文汉字 占用几个字节,要根据Oracle中字符集编码决定 查看oracle server端字符集 select userenv('langu ...

  3. 字符输入流Reader类和FileReader和字符输入流读取字符数据

    java.io.Reader:字符输入流,是字符输入流的最顶层的父类,定义了一些共性的成员方法,是一个抽象类 共性成员方法: int read();读取单个字符并返回 int read(char[] ...

  4. 数据类型和typeof操作符

    虽然学习js有一段时间了,但是对js的基础语法却是有些生疏.最近在看jquery源码,决定随带总结一些基础的语法知识.今天总结一下数据类型和typeof,这在写js的时候,是不得不知道的知识. 数据类 ...

  5. Core Java 总结(字符和字符串类问题)

    所有代码均在本地编译运行测试,环境为 Windows7 32位机器 + eclipse Mars.2 Release (4.5.2) 2016-10-17 整理 字符,字符串类问题 正则表达式问题 J ...

  6. Java:IO流其他类(字节数组流、字符数组流、数据流、打印流、Properities、对象流、管道流、随机访问、序列流、字符串读写流)

    一.字节数组流: 类 ByteArrayInputStream:在构造函数的时候,需要接受数据源,而且数据源是一个字节数组. 包含一个内部缓冲区,该缓冲区包含从流中读取的字节.内部计数器跟踪 read ...

  7. 字节流, FileOutputStream类,FileInputStream类,复制文件,字符流

    字节输出流OutputStream OutputStream此抽象类,是表示输出字节流的所有类的超类.操作的数据都是字节 基本方法: 子类可继承调用以上方法 FileOutputStream类 构造方 ...

  8. mysql基础-数据类型和sql模式-学习之(三)

    0x01 mysql的两种方向: 开发DBA:数据库设计(E-R关系图).sql开发.内置函数.存储历程(存储过程和存储函数).触发器.时间调度器(event scheduler) 运维----> ...

  9. Java数据类型和MySql数据类型对应一览

    类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述             VARCHAR L+N VARCHAR java.lang.String 12   CHAR N ...

随机推荐

  1. C++库的随机数生成

    C++库为我们提供了很多生成随机数的方法. 使用C的随机数生成法 先学过C语言,或者仅仅用C++做算法的人.对rand()是非常熟悉了.这个函数没有参数,生成0到RAND_MAX的随机数(RAND_M ...

  2. Turtle绘图——python简单上手小案例

    Turtle绘图 Turtle模块提供了在二维平面上移动的环境. Turtle可以实现位置.航向和各种可能的状态和动作. import turtle as tu roo = tu.Turtle() # ...

  3. Jenkins + maven + svn 自动部署项目

    1.安装Jenkins sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins. ...

  4. 『现学现忘』Git后悔药 — 29、版本回退git reset --mixed命令说明

    git reset --mixed commit-id命令:回退到指定版本.(mixed:混合的,即:中等回退.) 该命令不仅修改了分支中HEAD指针的位置,还将暂存区中数据也回退到了指定版本. 但是 ...

  5. springboot connecting to :mongodb://127.0..0.1:27017/test authentication failed

    账号的权限不够,可能是insert进去的脚本的角色有问题 use admin db.createUser({user:'账号',pwd:'密码',roles:[{role:'userAdminAnyD ...

  6. Note -「Dijkstra 求解 MCMF」

    食用前请先了解 SPFA + Dinic/EK 求解 MCMF. Sol. 总所周知,SPFA 牺牲了.于是我们寻求一些更稳定的算法求解 MCMF. 网络流算法的时间属于玄学,暂且判定为混乱中的稳定. ...

  7. jdbc 11: 封装自己的jdbc工具类

    jdbc连接mysql,封装自己的jdbc工具类 package com.examples.jdbc.utils; import java.sql.*; import java.util.Resour ...

  8. python subprocess相关操作

    python subprocess常用操作 1.subprocess模块的常用函数 函数 描述 subprocess.run() Python 3.5中新增的函数.执行指定的命令,等待命令执行完成后返 ...

  9. ABC251 题解

    典中典比赛 . 目录 A - Six Characters B - At Most 3 (Judge ver.) C - Poem Online Judge D - At Most 3 (Contes ...

  10. Axure RP 8 实现 圆角文本框 圆角带筛选的下拉列表框 可自动显示滚动条

    刚开始用Axure 会发现 Axure 元件库并不是很齐全,很多元件需要自己想办法解决 或者去网上去找.其实个人建议网上有现成的元件可以就下载就不必花时间去折腾.除非你也想练练手,原型这种东西除非高保 ...