关于自定义表类型遇到的问题~
2015-12-01 22:51
274 查看
有时候存储过程使用自定义表类型,就一个字~方便,类似于整个table直接传入到存储过程里面去玩,比起"万能"的xml~ 还不用解析,直接能用~多方便。
[b]但是!!![/b]
使用自定义表变量,并不一定是一帆风顺的~比如说和如果调用的参数不是有数据库这边来组装,由程序去控制传入的时候,我目前发现的就有以下2个地方十分的需要注意
1、字段顺序!
在我们看来,自定义表变量,就当时一个普通的表进行使用,赋值,写插入,直接insert select 就完事了~但是,如果写在存储过程的传入参数里面,确不一定这样看,程序传入,生成的表变量,是严格按照表的字段顺序去插入的。其实也就是 insert into biao变量 values () 这样的语句。所以,有时候数据库调试没问题,但是程序调用的时候直接报错,有可能就是这个问题了,这个最直接的例子就是,在建自定义表类型中间的字段有个默认值,程序传的时候没赋值……然后一调用,直接就报插入字段数目不对了
2、标识列!
同理,标识列并不能在程序里面直接Insert进来,所以直接报错╮(╯_╰)╭。
应该来说,这2方面的问题可大可小,发现起来也不难,只是日常发现了~就跟大家分享一下
[b]但是!!![/b]
使用自定义表变量,并不一定是一帆风顺的~比如说和如果调用的参数不是有数据库这边来组装,由程序去控制传入的时候,我目前发现的就有以下2个地方十分的需要注意
1、字段顺序!
在我们看来,自定义表变量,就当时一个普通的表进行使用,赋值,写插入,直接insert select 就完事了~但是,如果写在存储过程的传入参数里面,确不一定这样看,程序传入,生成的表变量,是严格按照表的字段顺序去插入的。其实也就是 insert into biao变量 values () 这样的语句。所以,有时候数据库调试没问题,但是程序调用的时候直接报错,有可能就是这个问题了,这个最直接的例子就是,在建自定义表类型中间的字段有个默认值,程序传的时候没赋值……然后一调用,直接就报插入字段数目不对了
2、标识列!
同理,标识列并不能在程序里面直接Insert进来,所以直接报错╮(╯_╰)╭。
应该来说,这2方面的问题可大可小,发现起来也不难,只是日常发现了~就跟大家分享一下
相关文章推荐
- 20135202闫佳歆20135220谈愈敏-实验三
- Android 设置按钮、文本等组件颜色
- Sublime Text 3 安装
- 关于printf函数的返回值问题
- 用python产生一个好的秘钥
- Virtual PC 2007上 MS-DOS 6.22的安装方法
- dota玩家与英雄契合度的计算器,python语言scrapy爬虫的使用
- 结构体中的内存对齐
- MyEclipse 快捷键
- pip安装使用详解
- linux下如何设置vip(虚拟ip)
- 设计模式-模板方法
- MyEclipse 快捷键
- Gartner:智能SOC/情报驱动的SOC的五大特征
- Gartner:智能SOC/情报驱动的SOC的五大特征
- Gartner:智能SOC/情报驱动的SOC的五大特征
- LAMP 1.2 Apache编译安装问题解决
- Thread中的静态方法
- Quartz2D初体验之画线、画矩形
- 课程设计之第二次冲刺----第八天