关于自定义表类型遇到的问题~

有时候存储过程使用自定义表类型,就一个字~方便,类似于整个table直接传入到存储过程里面去玩,比起”万能”的xml~ 还不用解析,直接能用~多方便。

 

但是!!!

 

使用自定义表变量,并不一定是一帆风顺的~比如说和如果调用的参数不是有数据库这边来组装,由程序去控制传入的时候,我目前发现的就有以下2个地方十分的需要注意

 

1、字段顺序!

 

在我们看来,自定义表变量,就当时一个普通的表进行使用,赋值,写插入,直接insert select 就完事了~但是,如果写在存储过程的传入参数里面,确不一定这样看,程序传入,生成的表变量,是严格按照表的字段顺序去插入的。其实也就是 insert into biao变量 values () 这样的语句。所以,有时候数据库调试没问题,但是程序调用的时候直接报错,有可能就是这个问题了,这个最直接的例子就是,在建自定义表类型中间的字段有个默认值,程序传的时候没赋值……然后一调用,直接就报插入字段数目不对了

 

2、标识列!

 

同理,标识列并不能在程序里面直接Insert进来,所以直接报错╮(╯_╰)╭。

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐