位置: 编程技术 - 正文

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中关于数据库的说法正确的是)

  • 增值税留抵抵欠情况说明怎么写
  • 增值税发票确认平台怎么认证发票
  • 运动手环的税收分类编码是
  • 房产税的计算公式是多少
  • 增值税抵扣怎么取消
  • 有限责任公司的股东人数为多少
  • 增值税附加税包括哪些税种及税率
  • 哪些福利费不税前扣除
  • 申报增值税之后怎么做账
  • 一般纳税人每个月几号报税
  • 固定资产的确认条件是什么
  • 企业微信支付密码怎么设置
  • 销售机械设备的税率是多少
  • 个体户要申报
  • 营业外支出增值税率是多少
  • 完全成本法下期间费用应当包括
  • 一次性发放奖金个税怎么计算
  • 筹备期间的开办企业是指
  • 零申报的印花税怎么打印
  • 网页显示不全怎么回事
  • bios密码忘记了怎么清除,放电不行
  • 股东以无形资产投资,撤资时怎么算
  • 同一年可以先娶后嫁吗
  • 生产用厂房计入什么科目
  • tp-link无线路由器怎么样
  • uniapp关闭当前页面
  • 长期股权投资转出账务处理
  • 如何修复错误 OC3 INVT CHF100a
  • 进口增值税公式计算公式
  • vue父组件引入子组件
  • 投资性房地产出售时其他综合收益
  • 退回的企业所得税怎么做账
  • 特许权使用费20%
  • phpstorm怎么样
  • 如何用php制作表格
  • 金融资产减值损益怎么算
  • 自建办公楼装修效果图
  • php运算符号
  • php简单加密
  • 自产产品对外捐赠销项税额怎么计算
  • 背书转让的步骤
  • critical_section 结构
  • 《visual c++游戏编程基础》
  • 社保费和公积金一定要计提吗
  • 收到进项税发票
  • phpcms api
  • sql语句自动执行
  • sqlserver怎么显示结果窗口
  • 专票不抵扣认证怎么操作
  • 其他应付款如何清零
  • 一般纳税人购入商品会计分录
  • 经营范围中没有这个项目开票后果
  • 企业购买设备抵税
  • 发票遗失证明怎么写范文
  • 员工医药费属于什么费用
  • 应付账款平账调到哪个科目
  • 价外费用计入哪个科目
  • 往年附加税退税怎么做
  • 实收资本应补缴哪些税
  • 原始凭证丢了判刑吗
  • 建账的过程包括哪些内容
  • sql存储过程实例
  • windows自带安全
  • mac文档怎么传给winds
  • linux网络设置在哪里
  • hpm是什么格式的文件
  • 64位win7安装kb3038314补丁更新失败临时解决方法
  • LINUX下的磁盘编辑工具
  • 近期win7蓝屏
  • linux解密
  • Android游戏开发实训总结
  • javascript 基础
  • activitythread main方法
  • python3遍历
  • javascript如何
  • Jquery uploadify上传插件使用详解
  • jquery.form
  • unity2d寻路
  • 公司被分立,应将分立后的单位
  • 预缴税款怎么做账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设