oracle所有表中文与字段最大长度检测

用于Oracle数据库国产化为TiDB,由于国产化TiDB数据库与Oracle字段存储长度存在差异,需要在信创时做好转换

-- 中文检测

-- 执行该SQL生成所有相关字段的查询脚本

-- 每个字段对应一条SQL语句

-- 每条语句执行的结果包含 表名/字段名/包含中文行数(大于零代表包含中文)

sql 复制代码
SELECT 
	'SELECT '''||TABLE_NAME||''' AS TABLE_NAME ,  '''||COLUMN_NAME||''' AS COLUMN_NAME , SUM(CASE WHEN NVL(LENGTH( '||COLUMN_NAME ||'),0)< NVL(LENGTHB('||COLUMN_NAME||'),0) THEN 1 ELSE 0 END ) AS CHN_CHECK FROM 	YOUR_SCHEMA_NAME.'||TABLE_NAME||' WHERE '||COLUMN_NAME||' IS NOT NULL ;' AS CHARSET_SQL
FROM 
	DBA_TAB_COLS
WHERE 
	OWNER IN ('YOUR_SCHEMA_NAME')
	AND USER_GENERATED='YES'
	AND TABLE_NAME NOT LIKE 'BIN$%'
	AND TABLE_NAME NOT LIKE 'T/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE 'TT/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_BAK/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_BAK' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_TMP/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE 'TMP/_%' ESCAPE '/'
	AND DATA_TYPE='VARCHAR2';

-- 字段最大长度检测

-- 执行该SQL生成所有相关字段的查询脚本

-- 每个字段对应一条SQL语句

-- 每条语句执行的结果包含 表名/字段名/最大字符数

sql 复制代码
```sql
SELECT 
	'SELECT '''||TABLE_NAME||''' AS TABLE_NAME ,  '''||COLUMN_NAME||''' AS COLUMN_NAME ,  MAX(NVL(LENGTH( '||COLUMN_NAME||'),0)) AS MAX_LENGTH FROM YOUR_SCHEMA_NAME.'||TABLE_NAME||' WHERE '||COLUMN_NAME||' IS NOT NULL ;' AS LENGTH_SQL
FROM 
	DBA_TAB_COLS
WHERE 
	OWNER IN ('YOUR_SCHEMA_NAME')
	AND USER_GENERATED='YES'
	AND TABLE_NAME NOT LIKE 'BIN$%'
	AND TABLE_NAME NOT LIKE 'T/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE 'TT/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_BAK/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_BAK' ESCAPE '/'
	AND TABLE_NAME NOT LIKE '%/_TMP/_%' ESCAPE '/'
	AND TABLE_NAME NOT LIKE 'TMP/_%' ESCAPE '/'	
	AND DATA_TYPE='VARCHAR2';
复制代码
相关推荐
倔强的石头_6 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql