状态 |
描述 |
示例 |
Check Pending |
如果在一个表上定义了表检查约束,但还未验证新数据与那些已定义约束的兼容性,那么该表就处于这种状态。例如,DB2 load实用程序当开始在定义了表检查约束的表上执行载入操作时,就将表的状态设置为Check Pending状态。如果想使该表恢复为Normal状态,则需要执行一条SET INTEGRITY语句。要想获得更多的信息,请参阅约束。 |
已知载入的输入文件staff_data.del拥有以下内容:11,"Melnyk",20,"Sales",10,70000,15000: connect to sample; alter table staff add constraint max_salary check (100000 - salary >0); load from staff_data.del of del insert into staff; load query table staff; LOAD QUERY命令返回的信息显示,STAFF表处于Check Pending状态。 |
Load Pending |
如果在可提交数据之前,表上的正在执行的载入操作被异常终止,那么该表就处于这种状态。若要使该表恢复Normal状态,则需要调用load terminate、load restart或load replace操作。 |
已知载入的输入文件staffdata.del拥有大量数据(例如,20000条或更多记录),创建一个包含载入操作目标表的小型表空间,新建一个名为NEWSTAFF的表: connect to sample; create tablespace ts1 managed by database using (file '/home/melnyk/melnyk/NODE0000/SQL00001/ts1c1' 256); create table newstaff like staff in ts1; load from staffdata.del of del insert into newstaff; load query table newstaff; load from staffdata.del of del terminate into newstaff; load query table newstaff; connect reset; LOAD QUERY命令返回的信息显示,NEWSTAFF表处于Load Pending状态;在执行load terminate操作之后,该表就重新处于Normal状态。 |
Load in Progress |
这是一种只在执行载入操作期间才有效的临时状态。关于当载入操作失败或被中断时,如何解除表的Load in Progress状态的信息,请参阅 Movement Utilities Guide and Reference中关于载入操作之后的暂挂状态的小节。还请参阅Load in Progress表空间状态。 |
已知载入的输入文件staffdata.del拥有大量数据(例如,20000条或更多记录): update db cfg for sample using logretain recovery; backup db sample; connect to sample; create table newstaff like staff; load from staffdata.del of del insert into newstaff copy no; connect reset; 在执行载入操作时,从另一会话执行下列脚本: connect to sample; load query table newstaff; connect reset; LOAD QUERY命令返回的信息显示,NEWSTAFF表处于Load in Progress状态。 |
Normal |
如果表不是处于任何其他(异常的)表状态,那么它就处于Normal状态。Normal状态是表被创建之后的初始状态。 |
connect to sample; create table newstaff like staff; load query table newstaff; LOAD QUERY命令返回的信息显示,NEWSTAFF表处于Normal状态。 |
Not Load Restartable |
当执行完前滚操作,接着出现一个失败的载入操作,而该操作未被成功地重新启动或者终止时,表就处于这种状态。该表还将处于Load Pending状态。若要使该表恢复Normal状态,则需要执行一条LOAD TERMINATE命令。 |
已知载入的输入文件staffdata.del拥有大量数据(例如,20000条或更多记录): update db cfg for sample using logretain recovery; backup db sample; connect to sample; create tablespace ts1 managed by database using (file '/home/melnyk/melnyk/NODE0000/SQL00001/ts1c1' 256); create table newstaff like staff in ts1; connect reset; backup db sample; 该备份映像的时间戳为:20040629205935 connect to sample; load from staffdata.del of del insert into newstaff copy yes to /home/melnyk/backups; connect reset; restore db sample taken at 20040629205935; rollforward db sample to end of logs and stop; connect to sample; load query table newstaff; connect reset; LOAD QUERY命令返回的信息显示,NEWSTAFF表处于Not Load Restartable和Load Pending状态。 connect to sample; load from staffdata.del of del terminate into newstaff copy yes to /home/melnyk/backups; load query table newstaff; connect reset; LOAD QUERY命令返回的信息显示,NEWSTAFF表现在处于Normal状态。 |
Read Access Only |
在执行载入操作时,如果指定了ALLOW READ ACCESS选项,那么表就处于这种状态。Read Access Only是一个临时状态,它允许其他应用程序和实用程序读访问在执行载入操作之前就存在的数据。 |
已知载入的输入文件staffdata.del拥有大量数据(例如,20000条或更多记录): connect to sample; export to st_data.del of del select * from staff; create table newstaff like staff; import from st_data.del of del insert into newstaff; load from staffdata.del of del insert into newstaff allow read access; 在执行载入操作时,从另一会话执行下列脚本: connect to sample; load query table newstaff; select * from newstaff; connect reset; LOAD QUERY命令返回的信息显示,NEWSTAFF表处于Read Access Only和Load in Progress状态。该查询返回STAFF表所导出的内容,以及在执行载入操作之前,就存在于NEWSTAFF表中的数据。 |
Unavailable |
当前滚一个无法恢复的载入操作时,表就处于这种状态;这样的表只能被删除,或者从备份映像恢复它。 |
已知载入的输入文件staff_data.del拥有下列内容:11,"Melnyk",20,"Sales",10,70000,15000: update db cfg for sample using logretain recovery; backup db sample; 该备份映像的时间戳为:20040629182012 connect to sample; load from staff_data.del of del insert into staff nonrecoverable; connect reset; restore db sample taken at 20040629182012; rollforward db sample to end of logs and stop; connect to sample; load query table staff; connect reset; LOAD QUERY命令返回的信息显示,STAFF表处于Unavailable状态。 |