将数据库某种类型的字段更新为另一种类型

有时,我们可能会遇到这样的情况,当我们数据表的float类型精度不够时,可能需要把它统一调整成decimal或者money,而这时你一个一个去修改可能会崩溃,因为你无法从几千张表里确实找到所有的float类型的字段,而这时我们就需要自动的,批量的去处理它们。

实现思路:从系统表中查询所有用户建立的表,然后查询指定类型的所有字段,最后使用alter table alter column去更新这个字段.

知识点

  1. 游标
  2. exec
  3. SYSOBJECTS表和SYSCOLUMNS表

常用类型的typeid值

 xtype= 35 'text' 
 xtype=36 'uniqueidentifier' 
 xtype=48 'tinyint' 
 xtype=52 'smallint' 
 xtype=56 'int' 
 xtype=58 'smalldatetime' 
 xtype=59 'real' 
 xtype=60 'money' 
 xtype=61 'datetime' 
 xtype=62 'float' 
 xtype=98 'sql_variant' 
 xtype=99 'ntext' 
 xtype=104 'bit' 
 xtype=106 'decimal' 
 xtype=108 'numeric' 
 xtype=122 'smallmoney' 
 xtype=127 'bigint' 
 xtype=165 'varbinary' 
 xtype=167 'varchar'
 xtype=173 'binary' 
 xtype=175 'char' 
 xtype=189 'timestamp' 
 xtype=231 'nvarchar'
 xtype=239 'nchar' 
 xtype=241 'xml' 
 xtype=231 'sysname'

实现代码

DECLARE @tableName varchar(256)
DECLARE @columnName varchar(256)
DECLARE cursor2 CURSOR
FOR
SELECT NAME FROM SYSOBJECTS WHERE TYPE='U'
OPEN cursor2
FETCH NEXT FROM cursor2 INTO @tableName
WHILE @@fetch_status = 0  
    BEGIN
DECLARE cursor3 CURSOR
FOR						  
SELECT name FROM SYSCOLUMNS WHERE ID=OBJECT_ID(@tableName) and xtype=60
OPEN cursor3
FETCH NEXT FROM cursor3 INTO @columnName
WHILE @@fetch_status = 0  
    BEGIN
		print '更新表'+@tableName+',更新字段'+@columnName
		 
    Exec('ALTER TABLE '+@tableName+' ALTER COLUMN '+@columnName+' [float] ')
    
        FETCH NEXT FROM cursor3 INTO @columnName
    END
CLOSE cursor3
DEALLOCATE cursor3

        FETCH NEXT FROM cursor2 INTO @tableName
    END
CLOSE cursor2
DEALLOCATE cursor2

posted @   张占岭  阅读(1105)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
历史上的今天:
2018-07-20 java~使用自己的maven本地仓库
2017-07-20 Nginx学习笔记~目录索引
2017-07-20 nginx~为docker容器添加负载均衡
2017-07-20 docker~写个容器启动的bash脚本
2017-07-20 EF架构~mysql中时间戳字段被认为是主键自增
2012-07-20 代码之美~Lambda带给我们的不只是简洁
2011-07-20 LINQ中实现从集合中查找在指定子集合中存在的记录
点击右上角即可分享
微信分享提示