有时候存储过程使用自定义表类型,就一个字~方便,类似于整个table直接传入到存储过程里面去玩,比起"万能"的xml~ 还不用解析,直接能用~多方便。
但是!!!
使用自定义表变量,并不一定是一帆风顺的~比如说和如果调用的参数不是有数据库这边来组装,由程序去控制传入的时候,我目前发现的就有以下2个地方十分的需要注意
1、字段顺序!
在我们看来,自定义表变量,就当时一个普通的表进行使用,赋值,写插入,直接insert select 就完事了~但是,如果写在存储过程的传入参数里面,确不一定这样看,程序传入,生成的表变量,是严格按照表的字段顺序去插入的。其实也就是 insert into biao变量 values () 这样的语句。所以,有时候数据库调试没问题,但是程序调用的时候直接报错,有可能就是这个问题了,这个最直接的例子就是,在建自定义表类型中间的字段有个默认值,程序传的时候没赋值……然后一调用,直接就报插入字段数目不对了
2、标识列!
同理,标识列并不能在程序里面直接Insert进来,所以直接报错╮(╯_╰)╭。
应该来说,这2方面的问题可大可小,发现起来也不难,只是日常发现了~就跟大家分享一下