- 浏览: 102674 次
- 性别:
- 来自: 北京
文章分类
最新评论
char 2000 长度固定
varchar 4000 长度不固定
varchar2 4000 长度不固定
区别:
1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的, 比如,存储字符串“abc",对于CHAR (20),表示你存储的字符将占20个字节(包括17个空字符),而同样的VARCHAR2 (20)则只占用3个字节的长度,20只是最大值,当你存储的字符小于20时,按实际长度存储。
2.CHAR的效率比VARCHAR2的效率稍高。
3.目前VARCHAR是VARCHAR2的同义词。工业标准的VARCHAR类型可以存储空字符串,但是oracle不这样做,尽管它保留以后这样做的权利。Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库中varchar列可以存储空字符串的特性改为存储NULL值。如果你想有向后兼容的能力,Oracle建议使用VARCHAR2而不是VARCHAR。
何时该用CHAR,何时该用varchar2?
CHAR与VARCHAR2是一对矛盾的统一体,两者是互补的关系.
VARCHAR2比CHAR节省空间,在效率上比CHAR会稍微差一些,即要想获得效率,就必须牺牲一定的空间,这也就是我们在数据库设计上常说的‘以空间换效率’。
VARCHAR2虽然比CHAR节省空间,但是如果一个VARCHAR2列经常被修改,而且每次被修改的数据的长度不同,这会引起‘行迁移’(Row Migration)现象,而这造成多余的I/O,是数据库设计和调整中要尽力避免的,在这种情况下用CHAR代替VARCHAR2会更好一些。
发表评论
-
查找mysql中的非空表
2012-08-08 10:15 1901SELECT table_schema, table_type ... -
oracle横纵表转换的两种方式
2012-05-28 20:11 797select url,wmsys.wm_concat(alia ... -
查找oracle中的非空表
2012-05-17 11:19 10141.创建表 create table D ( NO N ... -
oracle
2012-05-09 21:24 0http://hwhuang.iteye.com/blog/5 ... -
blog
2011-12-26 16:45 0http://tech.it168.com/a2008/082 ... -
如何区别数据库访问的客户端
2011-12-06 22:17 886java.util.Properties props = ne ... -
varchar2(20)与varchar2(20 char)的区别
2011-11-23 11:28 0varchar2(20)与varchar2(20 cha ... -
如何查看数据库中被锁定的对象
2011-11-20 08:40 908select * from v$locked_object; ... -
如何找到数据库对象定义集合
2011-11-22 18:30 761如何找到数据库所有视图的定义 SQL> select v ... -
如何找到占用CPU极高的线程执行的SQL语句
2011-11-22 18:39 1222其实只是一条语句,步步递进 Select addr from ... -
如何手动找出当前数据库的top 5的SQL语句
2011-11-22 18:41 1834大家在statspack报告中经常会去查看top5的语句,但想 ... -
【ORACLE&DB2】中如何删除一个表中重复数据,仅留其中一行
2011-11-24 13:02 2453首先看一下ORACLE中的情况: delete from te ... -
Oracle内存表
2011-11-01 17:42 2335alter table xxx storage(buffer_ ... -
PL/SQL编程
2011-10-29 12:53 6151、基本块结构 DECLARE /* Dec ... -
常用oracle监控语句1
2011-10-28 12:55 7121、查看表锁 select V$SESSION.sid,v$s ... -
创建分区表
2011-10-27 20:12 0create table smsmsginfo ( ... -
编写sql语句注意事项
2011-10-27 19:56 8441、使用绑定变量 不良的写法: select * from b ... -
oracle主线文档
2011-10-27 09:05 657http://www.oracle.com/pls/db102 ...
相关推荐
Oracle 中 char 和 varchar2 的区别 Oracle 中 char 和 varchar2 是两种常用的字符串数据类型,它们之间的区别是很多开发者经常忽视的。下面我们将详细分析 Oracle 中 char 和 varchar2 的区别。 首先,char 是定...
### Oracle中的VARCHAR2(BYTE)与VARCHAR2(CHAR)区别详解 #### 一、引言 在Oracle数据库中,`VARCHAR2`是最常用的字符数据类型之一,用于存储变长的字符串。然而,在定义`VARCHAR2`类型时,可以选择指定长度为`BYTE`...
今天我们将深入探讨三种常见的字符串类型:`char`、`varchar`和`varchar2`,它们在不同的数据库系统中有着微妙的区别。 1. **char类型** `char`是一种固定长度的字符串类型,无论实际存储的数据是否填满指定长度,...
本文主要讨论了int、char和varchar这三种常见数据类型在性能上的差异。通常,这些差异在无索引和有索引的情况下的表现会有所不同。 首先,从无索引的全表扫描角度来看,测试结果显示int和bigint(即i8)在查询性能...
在MySQL数据库中,`CHAR`和`VARCHAR`是两种常见的字符串数据类型,它们在存储和处理数据时具有不同的效率特点。理解这两种类型的差异对于优化数据库性能至关重要。 `CHAR`是一种固定长度的数据类型,这意味着无论...
### Oracle CHAR, VARCHAR, VARCHAR2 的区别与使用方法 在 Oracle 数据库中,字符串类型是极为常见的数据类型之一,主要用于存储文本数据。其中最常用的三种类型包括:`CHAR`, `VARCHAR`, 和 `VARCHAR2`。这三种...
2. 字符长度的相似性:如果字段的长度大部分时间相近,如电话号码,即使长度较长,使用CHAR可能更合适,因为长度变化不大,浪费的空间相对有限。 3. 空间效率:如果字段长度差异大,经常存储较短的字符串,VARCHAR能...
在MySQL数据库中,CHAR和VARCHAR是两种常用的字符串数据类型,它们在存储和处理字符串时有显著的区别。理解这些差异对于优化数据库性能和节省存储空间至关重要。 首先,CHAR和VARCHAR都是预定义长度的数据类型,但...
2、存储的时候,VARCHAR不会先补足空格后再存储,但如果是用户在插入时特地加了空格那就会如实存储,而不会给删除。 3、读取数据时,CHAR总是会删除尾部空格(哪怕是写入时包含空格)。 4、读取数据时,VARCHAR总是...
nchar_char_varchar与nvarchar有何区别?
在字符型数据中,用的最多的就是 Char与Varchar两种类型。前面的是固定长度,而后面的是可变长度。现在我们需要考虑的是,在什么情况下使用Char字符型数据,什么情况下采用 Varchar字符型数据。 一、VARCHAR与CHAR...
本文主要探讨的是两种常见字符串类型:`CHAR`和`VARCHAR2`,它们在使用上有何不同,并且会涉及一些相关的Oracle数据库功能。 首先,`CHAR`是定长字符串类型,这意味着当你声明一个`CHAR(10)`字段时,无论你存储的...
### char、varchar、nchar、nvarchar 四种类型的区别 在数据库设计中,选择合适的字段类型对于确保数据的准确性和提高查询效率至关重要。对于字符类型的字段,SQL Server 提供了 `char`、`varchar`、`nchar` 和 `...
MySQL中的CHAR和VARCHAR是两种常见的字符串数据类型,用于存储文本数据。它们在数据库设计和优化中扮演着重要的角色,理解它们的区别和使用场景至关重要。 首先,让我们深入了解一下两者的演变。在MySQL 5.0.3之前...
在MySQL数据库中,CHAR和VARCHAR是两种常见的字符串数据类型,它们在存储和处理方式上有着显著的区别,这对于数据库设计和性能优化至关重要。 首先,CHAR是一种固定长度的数据类型。这意味着无论你存储的实际数据有...
在SQL Server数据库管理系统中,字符数据类型是存储文本信息的基础,包括`char`、`varchar`、`nchar`和`nvarchar`等几种常见的类型。这些数据类型在存储字符串时有着不同的特性和用途,理解它们之间的区别对于正确...
在存储方式上,`char`对英文字符(ASCII)占用1个字节,而`varchar`对每个英文字符占用2个字节。对于汉字,两者都是占用2个字节。这是因为`varchar`默认使用UTF-8编码,而`char`在非Unicode环境下通常使用单字节编码...