查看表空间使用情况 db2pd -d dbname -tablespaces
扩大表空间有3种方法:
扩展容器50G
db2 "alter tablespace tablespace_name extend (file '/data1/ts2/con0' 50G,file '/data1/ts2/con1' 50G)"
2增加容器,不过会rebalance,影响系统性能
db2 "alter tablespace tablespacename add (file '/data1/ts2/con2' 50G)"
3通过alter tablespace begin new stripe set 选项,该选项不rebalance,不会对系统性能造成影响,但它会造成数据偏移。
db2 "alter tablespace tablespace_name begin new stripe set (file '/data1/ts2/con3' 10G)"
通常是指标识列,也可用函数指定。自增由函数指定。把函数设置为列的默认值IF OBJECT_ID ('dbonew_employees', 'U') IS NOT NULL
DROP TABLE new_employees
GO
CREATE TABLE new_employees
(
id_num int IDENTITY(1,1),
fname varchar (20),
minit char(1),
lname varchar(30)
)
INSERT new_employees
(fname, minit, lname)
VALUES
('Karin', 'F', 'Josephs')
INSERT new_employees
(fname, minit, lname)
VALUES
('Pirkko', 'O', 'Koskitalo')db2 => CREATE TABLE test_create_tab2 (
db2 (cont) => id INT NOT NULL PRIMARY KEY generated always as identity,
db2 (cont) => val VARCHAR(10)
db2 (cont) => );
DB20000I SQL 命令成功完成。
db2 => INSERT INTO test_create_tab2(val) VALUES ('NO id');
DB20000I SQL 命令成功完成。
这里和 SQL Server 一样,大家都不能手动指定那个 自增id 的数值
db2 => INSERT INTO test_create_tab2(id, val) VALUES (1, 'id no use');
DB21034E 该命令被当作 SQL 语句来处理,因为它是无效的“命令行处理器”命令。在
SQL 处理期间,它返回:
SQL0798N 不能为定义为 GENERATED ALWAYS 的列 "ID" 指定值。 SQLSTATE=428C9
这里和 SQL Server 不一样,SQL Server 会自动排除掉那个自动递增的列
db2 => INSERT INTO test_create_tab2 VALUES ('Is Auto ');
DB21034E 该命令被当作 SQL 语句来处理,因为它是无效的“命令行处理器”命令。在
SQL 处理期间,它返回:
SQL0117N 赋值数目与指定的或隐含的列数或变量数不一样。 SQLSTATE=42802
关于 初始数值的设定。
db2 => drop TABLE test_create_tab2;
DB20000I SQL 命令成功完成。
db2 => CREATE TABLE test_create_tab2 (
db2 (cont) => id INT NOT NULL PRIMARY KEY generated always as identity
db2 (cont) => (Start With 100
db2 (cont) => Increment by 1
db2 (cont) => minvalue 100
db2 (cont) => maxvalue 999999999
db2 (cont) => no cycle cache 5 no order),
db2 (cont) => val VARCHAR(10)
db2 (cont) => );
DB20000I SQL 命令成功完成。
db2 => INSERT INTO test_create_tab2(val) VALUES ('NO id');
DB20000I SQL 命令成功完成。
db2 => select from test_create_tab2;
ID VAL
----------- ----------
100 NO id
1 条记录已选择。
db2 => select identity_val_local() from SYSIBMSYSDUMMY1;
1
---------------------------------
100
1 条记录已选择。
如果该字段不是主键,需要先设置该字段为主键:
alter table 表名 add primary key(字段名);
修改字段为自动增长
alter table 表名 change 字段名 字段名 字段类型 auto_increment;
select 自增列=identity(int,1,1), into #tb from tableName
drop table tabelNameselect into tableName from #tbdrop table #tb 其实可以直接在数据库中修改表的结构,增加一列(就是内容递增的那列),把这列设为标识列,自动递增1。保存一下就行了。
在sql2000中可以这样,不过感觉不怎么好如果表中关系多了,不建议这样用if exists (select from dbosysobjects where id = object_id(N'[dbo][p_setid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo][p_setid]
GO
--将表中的某个字段转换成标识字段,并保留原来的值
--注意,因为要删除原表,所以,如果表和其他表的关联,这些关联要重新创建
--调用示例
exec p_setid '表名','要转换的字段名'
--/
CREATE PROC P_SETID
@tbname sysname, --要处理的表名
@fdname sysname --要转换为标识字段的字段名
as
declare @s1 varchar(8000),@s2 varchar(8000),@tmptb sysname
select @s1='',@s2='',@tmptb='[tmp_'+@tbname+'_bak]'
select @s1=@s1+',['+name+']'
+case name when @fdname then '=identity(bigint,1,1)' else '' end
,@s2=@s2+',['+name+']'
from syscolumns where object_id(@tbname)=id
select @s1=substring(@s1,2,8000),@s2=substring(@s2,2,8000)
exec('select top 0 '+@s1+' into '+@tmptb+' from ['+@tbname+']
set identity_insert '+@tmptb+' on
insert into '+@tmptb+'('+@s2+') select '+@s2+' from ['+@tbname+']
set identity_insert '+@tmptb+' off
')
exec('drop table ['+@tbname+']')
exec sp_rename @tmptb,@tbname
go
--使用测试
--创建测试的表
create table 表(编号 bigint,姓名 varchar(10))
insert into 表
select 1,'张三'
union all select 2,'李四'
union all select 4,'王五'
go
--调用存储过程,将编号字段改为标识字段
exec p_setid '表','编号'
go
--显示处理结果
select from 表
--显示是否修改成功
select name from syscolumns
where object_id('表')=id and status=0x80
go
--删除测试
drop table 表
你说的这个我觉得应该是向让数据库里面的某个字段是有序增长的看mysql数据库,可以设置组件递增的,oracle和db2这个可以创建一个序列,使用的时候去序列里面取,每次取完序列会自动增长1,具体实现方法可以百度一下有很多db2pd -d 数据库名 -tablespace 在现实结果中如下就是 AS是automaitc storage自动存储的缩写,AR是autoresize的缩写 AS是yes证明表空间是自动存储的 AR是yes证明表空间是自动扩展的statistics
AS AR
YES NO
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)