学习Oracle------认识VARCHAR2

学习Oracle------认识VARCHAR2

VARCHAR2 是 Oracle 数据库中专门用于存储可变长度字符串的数据类型,它是 Oracle 对标准 SQL 数据类型 VARCHAR 的增强和替代。以下是全面解析:


核心概念

  1. 名字含义

    • VAR = Variable(可变)
    • CHAR = Character(字符)
    • 2 = Oracle 专有实现的版本标识
  2. 本质

    • 存储可变长度的字符串(仅占用实际字符所需空间)
    • 最大长度:4000 字节(Oracle 12c 之前)或 32767 字节(Oracle 12c+)
    • 必须指定长度:VARCHAR2(50)

VARCHAR 的关键区别

特性VARCHAR2 (Oracle)VARCHAR (标准SQL)
来源Oracle 专有数据类型ANSI SQL 标准数据类型
空字符串处理存储为 NULL可能存储为空字符串(取决于实现)
未来兼容性Oracle 承诺永久支持Oracle 已标记为"不建议使用"
实际使用Oracle 首选字符串类型(占90%+)极少使用(仅为兼容标准保留)
性能完全优化同义处理(实际映射到VARCHAR2)

⚠️ Oracle官方声明
“请始终使用VARCHAR2,因为VARCHAR的行为可能在未来的Oracle版本中改变”
Oracle Database SQL Language Reference


技术特性

  1. 存储机制

    -- 创建表
    CREATE TABLE user_info (name VARCHAR2(20)  -- 实际存储长度取决于数据
    );-- 插入数据
    INSERT INTO user_info VALUES ('Alice');    -- 实际占用:5字节
    INSERT INTO user_info VALUES ('Bob');       -- 实际占用:3字节
    
  2. 长度单位

    • 字节模式(默认):VARCHAR2(50) = 50字节
    • 字符模式(多字节字符集时用):
      VARCHAR2(50 CHAR)  -- 可存储50个中文字符(UTF-8下约150字节)
      
  3. 空值处理

    INSERT INTO user_info VALUES ('');  -- Oracle会将其转为NULL存储
    

为什么用 VARCHAR2 而不用 CHAR?

场景VARCHAR2 优势CHAR 适用场景
存储人名/地址节省空间(不填充空格)固定长度数据(如国家代码)
长文本片段支持32767字节(12c+)最大2000字节
性能考量查询更快(更少I/O)固定长度记录高速检索
网络传输传输数据量更小无优势

最佳实践示例

  1. 基础使用

    CREATE TABLE employees (id NUMBER,first_name VARCHAR2(50 CHAR),  -- 支持多语言姓名email VARCHAR2(100)            -- 邮箱地址
    );
    
  2. 带约束

    CREATE TABLE products (sku VARCHAR2(20) PRIMARY KEY,  -- 主键desc VARCHAR2(500) NOT NULL     -- 非空描述
    );
    
  3. PL/SQL 变量

    DECLAREuser_input VARCHAR2(4000);  -- 最大支持4000字节
    BEGINuser_input := '用户输入内容...';
    END;
    

版本演进

Oracle 版本关键变化
7.3-11g最大4000字节
12c+扩展模式支持32767字节(需开启)
21c支持VARCHAR2作为JSON字段类型

💡 12c+ 大字符串开启方法

ALTER SYSTEM SET max_string_size=EXTENDED;

使用建议

  1. 首选场景

    • 用户输入文本(姓名/地址/描述)
    • 非结构化数据存储
    • 键值对中的值
  2. 避免场景

    • 存储超过32767字节的文本 → 改用 CLOB
    • 固定长度代码(如ISO国家代码)→ 用 CHAR(2)
  3. 性能提示

    -- 为高频查询字段添加索引
    CREATE INDEX idx_name ON employees(first_name); -- 避免超长定义(合理预估长度)
    description VARCHAR2(500)  -- 好于 VARCHAR2(4000)
    

📌 总结VARCHAR2 是 Oracle 中处理可变长度文本的黄金标准,兼顾存储效率、性能与兼容性,是字符串字段的默认选择。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/83771.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

记录jackson解析出错

Jackson 属性名大小写 Bug 记录 问题描述 在前后端交互过程中,前端传递的 JSON 字段名为驼峰风格(如 qTitle),后端 Java 实体类字段名也为驼峰(如 private String qTitle;)。 但在反序列化时,…

泰国数码电商系统定制|3C产品详情泰语化+售后管理,适配泰国数码零售

随着全球数字化的加速,电商行业正在迅速发展,尤其是以泰国为代表的东南亚市场。泰国不仅是一个拥有庞大消费者群体的市场,而且其日益增长的互联网使用率和手机普及率使得数码产品的销售潜力巨大。在这样的大背景下,针对泰国市场的…

59、定制化原理-SpringBoot定制化组件的几种方式

59、定制化原理-SpringBoot定制化组件的几种方式 在Spring Boot中,定制化组件的方式多样,以下是几种常见的方法及其原理: #### 修改配置文件 通过修改application.properties或application.yml文件,利用ConfigurationProperties注…

机器学习--分类

阳性(Positive)和阴性(Negative) 阳性(Positive) 正类:通常指的是我们关注的类别或事件;阴性(Negative) 负类: 指的是与阳性相反的类别或事件。…

三星MZQL2960HCJR-00BAL高性能固态硬盘控制器SSD云计算和高端存储专用 电子元器件解析

MZQL2960HCJR-00BAL 电子元器件解析 1. 基本类型与功能 MZQL2960HCJR-00BAL 是 三星(Samsung) 推出的一款 企业级NVMe SSD主控芯片,属于 高性能固态硬盘控制器,专为 数据中心、云计算和高端存储 设计。 关键特性: 接…

Blender——建构、粒子、灯光、动画

Blender是一款开源的三维建模和动画软件,可用于创建3D模型、动画、渲染图像和视频,还支持雕刻、纹理绘制、粒子系统等功能。 建构篇: 基本操作: 视角的控制: 控制观察视角: 鼠标中键 平移视图: Shift鼠标中键 缩放视…

节日快乐啊

<section data-role"paragraph" class"_135editor"> <p> <br/> </p> </section> <p> 玛哈特2025中国国际金属成形展览会邀请函 </p><style>* { margin: 0; …

PHP和Node.js哪个更爽?

先说结论&#xff0c;rust完胜。 php&#xff1a;laravel&#xff0c;swoole&#xff0c;webman&#xff0c;最开始在苏宁的时候写了几年php&#xff0c;当时觉得php真的是世界上最好的语言&#xff0c;因为当初活在舒适圈里&#xff0c;不愿意跳出来&#xff0c;就好比当初活在…

LeetCode - 387. 字符串中的第一个唯一字符

题目 387. 字符串中的第一个唯一字符 - 力扣&#xff08;LeetCode&#xff09; 思路 用哈希表统计每个字符出现的次数 创建一个 unordered_map<char, int>&#xff0c;遍历字符串&#xff0c;把每个字符出现的次数存进去。 再遍历字符串&#xff0c;找到第一个只出现…

python从环境变量和配置文件中获取配置参数

前言 从环境变量和配置文件中获取配置参数&#xff0c;相关库&#xff1a; python-dotenv&#xff1a;第三方库&#xff0c;需要使用pip安装configparser&#xff1a;标准库 代码 test.ini [mysql] host "192.168.0.10" port 3306 user "root" pas…

HarmonyOS5 运动健康app(一):健康饮食(附代码)

一、核心数据模型设计 代码通过两个接口构建了饮食管理的基础数据结构&#xff1a; interface footItem {name: string; // 营养名称&#xff08;蛋白质/碳水/脂肪&#xff09;weight: number; // 重量&#xff08;克&#xff09; }interface DietItem {name: string; // 食物…

MQ选型及RocketMQ架构总览

一、什么是MQ MQ&#xff08;MessageQueue&#xff09; Message(消息)&#xff1a;消息是在不同进程之间传递的数据&#xff0c;这些进程可以在同一台机器上&#xff0c;也可以在不同的机器上。 Queue&#xff08;队列&#xff09;&#xff1a;队列原意是指一种具有FIFO&#…

python与java的区别

java老程序员来学习python了&#xff0c;记录一下两种类型语言的区别&#xff1a; Python与Java变量类型对比 python里面定义变量不需要指定变量的数据类型&#xff0c;并且是可以修改成其他类型java里面定义变量要指定变量的数据类型&#xff0c;指定以后不可以修改成其他数据…

固件签名技术深度解析:HSM模块如何守护设备安全,CAS系统如何赋能产业升级

引言&#xff1a;数字时代的固件安全危机 在万物互联的今天&#xff0c;全球设备固件安全事件频发&#xff1a;某汽车品牌因固件漏洞导致百万车辆被远程控制&#xff0c;某医疗设备厂商因固件篡改引发数据泄露&#xff0c;某工业控制系统因非法固件升级造成生产线瘫痪……这些…

修改Typora快捷键

代码 的默认快捷键为&#xff1a; 这对我来说不太友好&#xff0c;太难按了&#xff0c;而且我电脑右边的Ctrl键坏了&#xff0c;这意味着我只能一个左手去按这3个键的组合&#xff0c;这更是难上加难了&#xff0c;于是想到改一下快捷键&#xff0c;代码块 是Ctrl Shift K&…

Bellman-Ford算法(详解版)

Bellman-Ford算法 Bellman-Ford算法是用来解决,对于有负权的图的**单源最短路径**.因为DJ算法不可以解决对于负权的图,所以使用这个算法来求解.但是依旧不可以有负回路.因为负回路就没有存在单源最短路径这一说. BF的另一个重要的用途就是用来检测**是不是存在负回路** 思路…

《HarmonyOSNext的ForEach数组渲染の核心玩法与避坑指南》

《HarmonyOSNext教学宝典&#xff1a;ForEach数组渲染全攻略与性能优化》 #HarmonyOS开发 #ArkTS实战 #组件解析 &#x1f3af; ForEach组件完全指南&#xff1a;数组循环渲染核心机制 举个栗子&#x1f330;&#xff1a; ForEach相当于智能印刷机&#xff0c;将数组元素自动转…

单片机 - STM32F407 ADC 模式详解:单次转换、连续转换、扫描模式、非扫描模式

STM32F407 ADC 模式详解&#xff1a;单次转换、连续转换、扫描模式、非扫描模式 前言 在 STM32F407 中&#xff0c;ADC&#xff08;模数转换器&#xff09;模块常用于采集模拟信号&#xff0c;比如读取光敏电阻、电压、电流、温度传感器等。STM32 的 ADC 模式较多&#xff0c…

开源模型应用落地-工具使用篇-从零开始搭建Qdrant Web UI-可视化管理工具-Windows(十)

一、前言 Qdrant 是一个高性能的向量搜索引擎&#xff0c;广泛应用于相似性搜索、推荐系统和大规模数据检索等场景。虽然其原生 API 提供了强大的功能&#xff0c;但对于开发者和运维人员来说&#xff0c;缺乏直观的可视化界面常常增加了使用门槛。为了解决这一问题&#xff0c…

高频交易技术:订单簿分析与低延迟架构——从Level 2数据挖掘到FPGA硬件加速的全链路解决方案

高频交易技术&#xff1a;订单簿分析与低延迟架构——从Level 2数据挖掘到FPGA硬件加速的全链路解决方案 一、引言&#xff1a;高频交易的技术本质 1.1 速度即利润的微观战场 数据揭示&#xff1a;据NYSE实测&#xff0c;每降低1微秒延迟可获得年化$700-1500万套利窗口&#…