免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6357 | 回复: 6
打印 上一主题 下一主题

关于 DB2 的自增长列(已解决,恶心) [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-21 10:04 |只看该作者 |倒序浏览
本帖最后由 snow888 于 2010-04-21 12:33 编辑

建表脚本
  1. create table test (
  2. a numeric(19,0) not null generated by default as identity( minvalue +1 maxvalue +200000),
  3. b char(8),
  4. constraint pk_test primary key (a));
复制代码
插入数据时使用如下语句
  1. db2 "insert into test values('aaaaaa')"
复制代码
居然报错了,错误信息如下:

DB21034E  The command was processed as an SQL statement because it was not a
valid Command Line Processor command.  During SQL processing it returned:
SQL0117N  The number of values assigned is not the same as the number of
specified or implied columns.  SQLSTATE=42802



何解???
  1. insert into test (b) values('aaaaa')
复制代码
OK!

论坛徽章:
0
2 [报告]
发表于 2010-04-27 11:59 |只看该作者
没指定的话,默认是插入全部列哦,可以这样
insert into test values(default,'aaaaa')

论坛徽章:
0
3 [报告]
发表于 2010-04-27 13:53 |只看该作者
楼上说的对,没有指定列时,会插入全部列值,而你只提供了一个,我想你可能会认为序列会自己产生插入,这是对的,但在插入数据时,确实要指定列,除了有序列的那个列外。

论坛徽章:
0
4 [报告]
发表于 2010-05-26 09:03 |只看该作者
这有啥恶心的,语法就是这样的,是有一定规则,不是你想怎么用就是怎么用的,用了一个错误的做法说语言学家恶心,这有点不大厚道吧

论坛徽章:
0
5 [报告]
发表于 2010-06-17 15:17 |只看该作者
LZ,呵呵

论坛徽章:
0
6 [报告]
发表于 2010-08-06 21:30 |只看该作者
lz 呵呵

论坛徽章:
0
7 [报告]
发表于 2010-08-06 22:02 |只看该作者
呵呵,基本sql语法问题吧。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP