位置: 编程技术 - 正文

SQL Server中修改“用户自定义表类型”问题的分析与方法(sql server 修改)

编辑:rootadmin

推荐整理分享SQL Server中修改“用户自定义表类型”问题的分析与方法(sql server 修改),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server中修改索引的语句,sql server中修改语句,sql server中修改数据,sql server中修改字段类型,sql server中修改列名称SQL语句,sql server中修改字段类型,sql server中修改字段类型,sql server中修改字段类型,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

SQL Server开发过程中,为了传入数据集类型的变量(比如接受C#中的DataTable类型变量),需要定义“用户自定义表类型”,通过“用户自定义表类型”可以接收二维数据集作为参数,在需要修改“用户自定义表类型”的时候,增加字段,删除字段,修改字段类型等,它没有像表一样的alter table语法来进行修改。

只能通过删除重建来实现,但是在删除“用户自定义表类型”的时候会提示有对象引用它(某些存储过程用到了这个“用户自定义表类型”),因此无法删除。

为了达到公用的目的,有时候一个TableType可以在多个地方分别被引用到,这样的话,势必要先删除所有的引用了这个“用户自定义表类型”的对象(存储过程等)

如果这个“用户自定义表类型”被多个存储过程引用,那么就要分别删除多个引用了“用户自定义表类型”的存储过程,然后修改“用户自定义表类型”,在重建存储过程,这样做起来似乎有点绕,这个问题可以用过EXEC sys.sp_refreshsqlmodule这个系统函数来简介实现“用户自定义表类型”的定义

TableType的基本使用

如下创建一个用户自定义表类型

定义的TableType可以在用户自定义表类型中找到

创建两个存储过程,分别用到了上面定义的用户自定义表类型,模拟用户自定义表类型被引用的情况

此时的存储过程可以接收TableType参数并正常运行

TableType的修改

TableType类型不支持alter语法,也即无法直接修改TableType的定义

SQL Server中修改“用户自定义表类型”问题的分析与方法(sql server 修改)

那么只能通过删除TableType的方法来重建这个TableType,当删除的时候,仍然报错,提示“因为它正由对象 '***' 引用。可能还有其他对象在引用此类型。”

此时只能删除引用了这个TableType的对象来解决,下面可以查到那些对象引用了某一个TableType,然后分别删除,重建TableType,再重建存储过程,有点绕弯子。

可以先将自定义的某个TableType重命名,重命名的过程中有一个警告,这里先忽略它,随后可以直接Drop Type dbo.MyTableType

删除原TableType之后,重建(重定义)TableType

重建TableType之后,先前存储过程中用到这个TableType的存储过程是无法编译通过的

此时就需要重新刷新引用对象的定义

刷新完成之后,原存储过程就可以正常编译了

最后删除原始的TableType被重命名的TableType(被第一步重名的那个)

这样子,整个过程就无需因为修改TableType的定义而删除引用了TableType的对象了,在修改了TableType的定义之后,引用了这个TableType的对象可以正常运行,也可以根据修改之后的TableType做具体的使用

完整的脚本如下

总结:

TableType可以方便地接受二维数据作为参数,从而可以达到批量处理数据的目的,避免传递进去一大堆字符串,然后在对字符串解析的做法,从而可以在一定程度上提高sql的运行效率。

不过TableType的修改确实存在一定的问题,直接修改TableType会存在级联删除数据库对象的情况,可以通过“曲线救国”的方式,来减小工作量的情况下修改TableType。

好了,

标签: sql server 修改

本文链接地址:https://www.jiuchutong.com/biancheng/347089.html 转载请保留说明!

上一篇:详解SQL Server数据库状态和文件状态(sql server 数据库介绍)

下一篇:关于SQL Server中bit类型字段增删查改的一些事(在sql server中关于数据库的说法正确的是)

  • 外贸企业出口退税申报流程操作
  • 房地产房屋质量检测
  • 未出资到位的股东
  • 开业费用属于什么费用
  • 增值税改革后增值税申报表怎么填写
  • 固定资产残值账务处理
  • 资产负债表中应收账款
  • 固定资产原值错误的账务处理
  • 第一季度亏损第=季度盈利但累计还是亏损要交所得税吗?
  • 分步法和分批法思维导图
  • 三栏式和多栏式的账目有哪些
  • 政府补助款提现流程
  • 将债务转为资本会引起负债总额发生变动吗
  • 中药饮片适用增值税税率
  • 非同一控制下投资收益怎么计算
  • 农产品加工所得税
  • 没有税率的发票怎么开
  • 社保和公积金的钱可以取出来吗
  • 实验设备折旧率
  • 事业单位打印费计入什么科目
  • 事业单位坏账怎么处理
  • linux虚拟机在哪里输入命令
  • 651错误是怎么回事
  • 合并报表的收入是相加吗
  • php获取文件内容的函数
  • cookie 区别
  • 华为分享平时可不可以打开
  • 出差的误餐费会计分录
  • 企业支付宝给别人有什么用
  • 分红率与股息率有啥区别
  • PHP:pg_fetch_result()的用法_PostgreSQL函数
  • 公允价值计量转成本法 同一控制
  • 支付银行借款利息可以全额扣除吗
  • 一头公牛和一头母牛,答五个字
  • 个人从任职单位取得可公开交易的股票期权
  • 实收资本主要包括哪些
  • el-table-column formatter
  • java中ne
  • update-initramfs -u命令
  • 工业企业成本核算方法
  • ajax写接口
  • mysql存储过程cursor
  • 建安企业确认收入的依据
  • 怎么查电子发票真伪
  • 小型商贸企业
  • 企业所得税营业外收入
  • 政府补助是否可以抵扣
  • 疫情防控免税政策
  • 库存现金管理是财务分析的吗
  • 支付货款订金入什么科目
  • 应收帐款坏帐损失怎么算
  • 递延收益为什么属于负债
  • sql语句错误提示
  • hyper-v虚拟机无法初始化
  • windows中任务栏
  • tvt_reg_monitor_svc.exe进程是什么
  • windowssys
  • CentOS ip_conntrack: table full, dropping packet 的解决方法
  • ghost过的硬盘能恢复吗
  • windows8怎么关闭广告弹窗
  • vista starter
  • linux读取命令
  • win7旗舰版没有睡眠设置
  • win8怎么彻底删除安装的软件
  • Win7系统怎么打开文件后缀名
  • cpio压缩
  • cocos2dx游戏开发教程
  • python爬虫全套教程
  • 谷歌批量下载插件
  • jquery制作简单的网页
  • shell脚本加密不可破解
  • nodejs递归创建目录
  • js选择框全选
  • JavaScript的Number对象的toString()方法
  • android canvas rotate
  • 个人所得税代扣代缴会计分录
  • 如何做好税务局长
  • 江西发票税率
  • 香港买iphone要交多少税
  • 盐城滨海人口
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设