Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1565809
  • 博文数量: 201
  • 博客积分: 2812
  • 博客等级: 少校
  • 技术积分: 3029
  • 用 户 组: 普通用户
  • 注册时间: 2011-01-18 18:28
个人简介

从事数据库工作多年,目前看好分布式NeSQL/HTAP数据库在企业客户市场的发展。未来的主要方向是——致力于 NewSQL/HTAP 数据库的推广普及。

文章存档

2016年(1)

2015年(8)

2014年(23)

2013年(50)

2012年(32)

2011年(87)

分类: Sybase

2012-02-10 09:58:10

   熟悉ASE的人知道,在定义表的时候可以指定某个字段的值可以是自动增加的(即identity)字段;此外为了标识表中记录的增加、修改等变化,还可以定义一个timestamp类型的字段。在Sybase IQ中如何实现这两种字段的行为呢?下面就结合一个例子加以说明。
  
   1.创建包含identity和timestamp的字段
     create table test1(id unsigned bigint identity,name char(8),chg_idf timestamp default TIMESTAMP)
     或者
     create table test1(id unsigned bigint default AUTOINCREMENT,name char(8),chg_idf timestamp default TIMESTAMP)
 
     说明:对于identity字段可以有两种方法,即使用identity或是缺省值;而ASE的timestamp字段在IQ中只能使用缺省值方式定义,并且其类型为timestamp(为日期类型),不是ASE的binary(8)类型。
    
   2.执行insert和update,观察timestamp字段的变化
     insert into test1(name) values('aaa')
     执行为插入语句后,执行查询
          select * from test1
     下面是查询的示例输出:
            id                   name     chg_idf                
        -----------------------------------------------------
            1                    bbb      2012-02-10 18:52:12.547
 
      说明:
          我们看到,IQ为id字段自动生成相应值,chg_idf字段存放了IQ自动生成的记录插入时间信息
 
      我们再执行update,看看chg_idf的变化情况:
          update test1 set name = 'bbb' where id = 1
           select * from test
      下面是查询的示例输出:
           id                   name     chg_idf                
        -----------------------------------------------------
           1                    bbb      2012-02-10 18:58:06.192
     
       说明:当执行update修改记录时,IQ会自动把记录行的修改时间写到chg_idf字段中。
      
   3.修改identity字段值
     为了修改或为indentity字段指定某个值时,需要在执行insert或update语句之前设置identity_insert数据库选项,例如:
     set temporary option identity_insert = 'test1'; --指定目标表名
     update test1 set id = 2 where id =1;  --修改值
     insert into test1(id,name) values(3,'ddd');  --插入新记录,指定identity字段值
     commit;
     set temporay option identity_insert='';  --关闭对indentity字段的手工指定更新
   
     执行为插
阅读(2907) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~