SQL批量重命名中文字段名为对应拼音首字母字段名脚本

本文介绍如何使用SQL创建函数将中文字段名转换为其拼音首字母,并通过脚本批量重命名这些字段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

操作步骤1:生成获取中文字符串对应的拼音首字母字符串函数

操作步骤2:执行重命名中文字段名为拼音字首母字段名脚本

--1、SQL获取中文字符串对应的拼音首字母字符串函数
Create function fun_getPY
(
@str nvarchar(4000)
)
returns nvarchar(4000)
as
begin
declare @word nchar(1),@PY nvarchar(4000)

set @PY=''

while len(@str)>0
begin
set @word=left(@str,1)

--如果非汉字字符,返回原字符
set @PY=@PY+(case when unicode(@word) between 19968 and 19968+20901
then (
select top 1 PY
from
(
select 'A' as PY,N'驁' as word
union all select 'B',N'簿'
union all select 'C',N'錯'
union all select 'D',N'鵽'
union all select 'E',N'樲'
union all select 'F',N'鰒'
union all select 'G',N'腂'
union all select 'H',N'夻'
union all select 'J',N'攈'
union all select 'K',N'穒'
union all select 'L',N'鱳'
union all select 'M',N'旀'
union all select 'N',N'桛'
union all select 'O',N'漚'
union all select 'P',N'曝'
union all select 'Q',N'囕'
union all select 'R',N'鶸'
union all select 'S',N'蜶'
union all select 'T',N'籜'
union all select 'W',N'鶩'
union all select 'X',N'鑂'
union all select 'Y',N'韻'
union all select 'Z',N'咗'
) T
where word>=@word collate Chinese_PRC_CS_AS_KS_WS
order by PY ASC
)
else @word
end)
set @str=right(@str,len(@str)-1)
end

return @PY

end

--2、SQL批量重命名中文字段名为对应拼音首字母字段名脚本

--查询当前数据库中的所有中文字段名列表
select b.name as tablename,a.name as columnname from sys.columns a left join sys.objects b on a.object_id=b.object_id where UNICODE(a.name) BETWEEN 19968 AND 19968+20901 order by b.name

--定义游标查询变量
declare @TableName nvarchar(250)
declare @ColumnName nvarchar(250)

--声明读取数据库所有数据表名称游标mycursor1
declare mycursor1 cursor for select b.name as tablename,a.name as columnname from sys.columns a left join sys.objects b on a.object_id=b.object_id where UNICODE(a.name) BETWEEN 19968 AND 19968+20901 order by b.name

--打开游标
open mycursor1
--从游标里取出数据赋值到我们刚才声明的数据表名变量中
fetch next from mycursor1 into @TableName,@ColumnName
--如果游标执行成功
while (@@fetch_status=0)
begin

--定义重命名字段变量
declare @NewColumnName varchar (250)
select @NewColumnName=dbo.fun_getPY(@ColumnName)

declare @renameCommand nvarchar(2000)
set @renameCommand=@TableName+'.'+@ColumnName

--指定重命名字段指令
exec sp_rename @renameCommand,@NewColumnName,'column'

--用游标去取下一条记录
fetch next from mycursor1 into @TableName,@ColumnName
end

--关闭游标
close mycursor1
--撤销游标
deallocate mycursor1

--查询重命名后的当前数据库中的所有中文字段名列表
select b.name as tablename,a.name as columnname from sys.columns a left join sys.objects b on a.object_id=b.object_id where UNICODE(a.name) BETWEEN 19968 AND 19968+20901 order by b.name

### 如何在ArcGIS中连接表时不更改字段名 当在ArcGIS中执行表连接操作时,默认情况下可能会遇到字段名被修改的情况,这是因为ArcGIS为了防止重复字段名而自动添加前缀或其他字符。要保持原始字段名不变,可以采取以下方法: #### 方法一:使用地理处理工具中的“加入属性” 通过【工具箱】> 【分析】> 【连接和联接】下的“加入属性”工具,在此过程中可以选择不重命名字段的方式进行连接[^1]。 #### 方法二:创建视图或查询层 对于支持SQL数据库(如Oracle、PostgreSQL),可以通过定义SQL语句来构建视图或者查询层,从而实现自定义字段映射而不改变原有字段名称[^2]。 #### 方法三:调整环境设置 进入ArcMap 或 ArcPro 的选项菜单,找到“常规”标签页下有一个名为“编辑器”的部分,这里有一项叫做“允许覆盖现有字段”,勾选此项可以在某些场景下帮助保留原字段名。 #### Python脚本解决方案 如果熟悉Python编程,则可编写简单的Pyhton脚本批量处理多个图层之间的关联关系,并确保目标字段不会因连接过程受到影响。下面是一个简单例子: ```python import arcpy def join_tables_without_renaming_fields(target_layer, source_table, target_field, source_field): # 创建临时视图表以避免字段名冲突 temp_view = "in_memory\\tempView" sql_query = f"SELECT * FROM {source_table}" arcpy.MakeTableView_management(source_table, temp_view) # 执行连接操作并指定无须更改编码规则 arcpy.AddJoin_management( in_layer_or_view=target_layer, in_field=target_field, join_table=temp_view, join_field=source_field, join_type="KEEP_ALL" ) # 调用函数实例化参数 join_tables_without_renaming_fields("your_target_feature_class", "your_source_table", "common_id", "id") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值