Oracle CHR函数详解

CHR 是 Oracle 中一个基础的字符串函数,它的作用是将数字代码转换为对应的字符,可以理解为 ASCII 函数的反函数。

📖 CHR函数的语法与参数

CHR 函数的基本语法非常简洁:

sql

复制代码
CHR( n [ USING NCHAR_CS ] )
  • n**(NUMBER)** :用于检索字符的数字代码。
  • USING NCHAR_CS**(** 可选 ) :若指定此子句,函数将使用数据库的"国家字符集"进行转换,并返回 NVARCHAR2 类型。若不指定,则默认使用"数据库字符集"(如 AL32UTF8),返回 VARCHAR2 类型。

⚙️ 参数 n 与返回值处理规则

  • NULL :如果参数为 NULL,函数返回 NULL。
  • 负数 :如果参数为负数,函数将报错。
  • 单字节字符集 :若参数 n 在 0 到 255 之间,返回其直接对应的字符。若 n > 256,则返回 n mod 256 所对应的字符。
  • 多字节字符集 :参数 n 必须对应一个 完整的代码点 (Code Point),例如在 AL32UTF8 下,CHR(41378) 才是一个有效字符。由无效代码点可能导致结果不确定。

🛠️ 常用场景与典型示例

1. 🔧 用于生成特殊控制字符

这是 CHR 最常用的场景,常与 || 拼接符结合使用,在 SQL 语句中直接构建包含特殊字符的字符串。

场景 ASCII码 CHR函数 说明
制表符 9 CHR(9) 用于文本水平对齐
换行符 (LF) 10 CHR(10) 在字符串内插入换行
回车符 (CR) 13 CHR(13) 常用于与换行符组合 (CHR(13)
空格 32 CHR(32) 在字符串中插入空格
单引号 39 CHR(39) 在 SQL 语句中表示单引号
双引号 34 CHR(34) 用于包裹动态生成的标识符
'&' 符号 38 CHR(38) 避免被 SQL*Plus 视为替换变量
'@' 符号 64 CHR(64) 用于邮件地址等场景

场景示例:格式化地址

sql

复制代码
SELECT name || CHR(10) || address_line1 || CHR(10) || city || ', ' || state AS full_address
复制代码
FROM customers;

此语句将地址信息分行输出,提升可读性。

2. 🔄 ASCII码与字符互转

CHR 与 ASCII 函数功能相反,常用于字符编码的转换操作。

sql

复制代码
-- CHR将数字转换为字符,ASCII将字符转换为数字
复制代码
SELECT CHR(65) as char_from_ascii, ASCII('A') as ascii_from_char FROM DUAL;
复制代码
--结果: char_from_ascii: 'A', ascii_from_char: 65

场景示例:动态生成字母序列

sql

复制代码
--生成从A到Z的字母列表
复制代码
SELECT CHR(LEVEL + 64) AS letter FROM DUAL CONNECT BY LEVEL <= 26;

此查询利用层次查询和 CHR 函数,巧妙地生成了字母表序列。

相关推荐
这个DBA有点耶2 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶3 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技4 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend5 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence8 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql