转 ORACLE数据库它可以存储 中文 字节或字符

一:因为ORACLE数据库它可以存储字节或字符,例如 CHAR(12 BYTE) CHAR(12 CHAR)的意义是不同的.一般来说默认是存储字节,你可以查看数据库参数NLS_LENGTH_SEMANTICS的值。

1: SQL> show parameter nls_length_semantics;

2:

3: NAME                          TYPE        VALUE

4: ------------------------- ----------- -------------

5: nls_length_semantics          string      BYTE

如果定义为VARCHAR2(50 CHAR),那么该列最多就可以存储50个汉字,如果定义字段为VARCHAR2(50) 或VARCHAR2(50 BYTE)那么它最多可以存储多少个汉字就要视数据库字符集编码决定

二:ORACLE数据库汉字占用几个字节,要根据ORACLE中字符集编码决定,一般情况下,数据库的NLS_CHARACTERSET 为AL32UTF8或UTF8,即一个汉字占用三到四个字节。如果NLS_CHARACTERSET为ZHS16GBK,则一个字符占用两个字节.

1: SQL> COL PARAMETER FOR A24;

2: SQL> COL VALUE FOR A24     3:

SQL> SELECT * FROM v$nls_parameters WHERE PARAMETER=‘NLS_CHARACTERSET‘;

4:

5: PARAMETER                VALUE

6: ------------------------ ------------------------

7: NLS_CHARACTERSET         UTF8

8:

9: SQL>    10:

至于具体情况,可以通过LENGTHB或者VSIZE函数求得是占用字节数。

1: SQL> SELECT  LENGTH(‘您好‘) FROM DUAL;

2:

3: LENGTH(‘您好‘)

4: --------------

5:              2

6:

7:

SQL> SELECT  LENGTHB(‘您好‘) FROM DUAL;

8:

9: LENGTHB(‘您好‘)

10: ---------------

11:               6

12:

LENGTH函数求得是占用字符数,LENGTHB或者VSIZE函数求得是占用字节数。

VSIZE returns the number of bytes in the internal representation of expr. If expr is null, then this function returns null. This function does not support CLOB data directly. However, CLOBs can be passed in as arguments through implicit data conversion.

LENGTH是计算字符的个数,输入的参数先被转为字符类型计算

The LENGTH functions return the length of char. LENGTH calculates length using characters as defined by the input character set. LENGTHB uses bytes instead of characters. LENGTHC uses Unicode complete characters. LENGTH2 uses UCS2 code points. LENGTH4 uses UCS4 code points.

作者:潇湘隐者

出处:http://www.cnblogs.com/kerrycode/

->解决办法

1。

SQL> select userenv(‘language‘) from dual;

USERENV(‘LANGUAGE‘) AMERICAN_AMERICA.AL32UTF8

3.修改Linux的NLS_LANG环境变量,修改Oracle指定的Linux用户下面“.base_profile”文件,加入如下: export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"

4.执行.bash_profile,使环境变量设置生效,查看其值: $ echo $NLS_LANG MERICAN_AMERICA.AL32UTF8

至此,此次中文乱码的问题得已解决。

时间: 2024-08-03 04:31:49

转 ORACLE数据库它可以存储 中文 字节或字符的相关文章

浅析理解Oracle数据库体系结构和存储结构

一.Oracle体系结构 个人比喻帮助理解:类似于图书馆,去图书馆的客户(用户进程和服务进程等)需要调取资料,求助于图书管理员(实例)进入图书分区(数据库)进行资料查找.[如果比喻不当,欢迎指正,尽请谅解] - 第一部分是实例部分(为用户提供服务,管理数据库): 主要理解分成两个主要部分: (1)内存结构:(2)后台进程:与数据库进行交互 - 第二部分是数据库部分物理结构:(为实例提供服务,处理数据文件) 主要文件:数据文件,控制文件,重做日志文件 其他文件:归档日志文件,参数文件,口令文件等

编程开发之--Oracle数据库--存储过程和存储函数(1)

1.存储过程和存储函数 描述:指存储在数据库中供所有用户程序调用的子程序叫做存储过程.存储函数 区别:存储函数可以通过return子句返回一个函数的值 (1)存储过程 语法:create [or replace] PROCEDURE 过程名(参数列表) AS PLSQL子程序体; 存储过程的调用方式: a)exec/execute 过程名(); b)begin 过程名(); 过程名(); end; / 带参数的存储过程: 举例:为指定的员工涨100块钱工资,并且打印涨前以及涨后的工资. 在sql

关于java中实现在oracle数据库中实现对中文首字母进行排序的解决方案

首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值     SCHINESE_RADICAL_M   按照部首(第一顺序).笔划(第二顺序)排序     SCHINESE_STROKE_M   按照笔划(第一顺序).部首(第二顺序)排序     SCHINESE_PINYIN_M   按照拼音排序 oracle9i中新增了按照拼音.部首.笔画排序功能 用法示例: Java代码   拼音 SEL

python:连接Oracle数据库后控制台打印中文为??

打印查询结果,中文显示为了??? [('72H FCR', '2.0'), ('?????', '8.0')] E:\Python35\Lib\site-packages中新增文件: sitecustomize.py import os os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8' 原文地址:https://www.cnblogs.com/gcgc/p/11526420.html

Oracle 数据库中在使用中文模糊查询时输入中文查询不到结果的解决方法

添加环境变量 变量名:NLS_LANG 变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK

谈一谈计算机存储单位字节与字符

字节,是计算机信息技术用于计量存储容量的一种计量单位,也表示一些计算机编程语言中的数据类型和语言字符. 数据存储是以10进制表示,数据传输是以2进制表示的,所以1Kb不等于1000B 1kb =1024B, 1Mb =1024*1024B.其中1024=2的10次方. B与bit 数据存储是以字节 byte为单位,数据传输是以大多是以位bit,又称比特为单位,一个位就代表一个0或1(即二进制),每8个位bit组成一个字节(byte)是最小一级的信息单位. 1k = 1024 byte unico

Oracle数据库的体系结构和用户管理

一.Oracle体系结构 数据库的体系结构是指数据库的组成.工作过程.以及数据库中数据的组织与管理机制,要了解Oracle数据库的体系结构,必须理解Oracle系统的主要组件和重要概念. 1.Oracle体系结构概述 Oracle体系结构包含一系列组件,如下图所示,图中显示了Oracle体系结构中的主要组件,包括实例.用户进程.服务器进程.数据文件及其他文件,如参数文件.口令文件和归档日志文件等.从图中可以看出,实例和数据库是Oracle数据库体系结构的核心组成部分,也是最重要的两个概念:DBA

oracle数据库(一)

一.oracle函数依赖和范式理论 1.函数依赖 1)非平凡依赖:在关系R(U)中,对于U的子集X和Y,如果X->Y,Y不属于X的子集,则称X->Y是非平凡依赖. 2)平凡依赖:反之就是平凡依赖. 3)完全函数依赖:如果X->Y,对于任意X的子集X'存在X'-\>Y,则称X->Y为完全函数依赖. 4)部分函数依赖:如果X->Y,对于任意X的子集X'不存在X'-\>Y,则称X->Y为完全函数依赖. 5)传递函数依赖:如果X->Y,Y->Z,且Y-\

oracle数据库常见故障情况数据恢复分析

一.Oracle启动后无法工作或者数据库无法启动 一旦数据库出现无法启动的情况,首先需要检查system表是否为未损坏状态,通常情况而言,如果system表未被损坏那么很容易进行数据恢复,如果system表已经被损坏,那么就需要数据恢复工作人员手动对表结构进行分析核对,这样数据恢复的周期就相对较长,但是数据恢复成功率依然较高,不用担心数据恢复失败. 二.Oracle 数据库的ASM存储受到损坏 这种故障情况通常是因为ASM的部分设备故障或者由于ASM重置等原因导致的数据库数据丢失.出现这种情况后