网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > DB2教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.DB2中创建一个汉字拼音首字母的S.
.利用表空间的备份快速恢复IBM DB.
.DB2卸载后怎样恢复原来数据库中的.
.DB2的表数据加密.
.DBA应聘者在面试过程中经常被问及.
.全面了解DB2数据库中的各数据类型.
.让DB2数据库使用所有内存的方法(.
.经验总结:DB2数据库功能及性能使.
.DB2数据库中提高INSERT性能详解(.
.DB2数据库部分日常实用操作(1).
.DB2 Performance Expert 简化性能.
.如何将Siebel 7从DB2 UDB V8迁移.
.正确认识DB2数据库分区兼容性和并.
.用DB2 V9.1for z/OS实现应用程序.
.在DB2数据库里面如何更新执行计划.
.全面解析DB2性能调优方面的二十个.
.DB2 V9.5工作负载管理之阈值(THR.
.AIX环境下实现DB2向Windows 2000.
.实例讲解IBM DB2中提高并发度的三.
.选择适合自己的DB2 9.5客户机连通.

DB2数据库创建存储过程时遇到的错误现象

发表日期:2008-5-15


问:在 Unix 操作系统下,有时会发生当 DB2 用户使用如:

db2 -td@ -vf <存储过程创建脚本文件>

创建存储过程失败的情况,而查看 db2diag.log 文件则发现有类似如下报错信息:

2002-10-05-13.47.40.075759 Instance:db2inst1 Node:000

PID:1355876(db2agent (ABC) 0) TID:1 Appid:OC10103F.OD12.017302185202

oper system services sqloChangeFileOwnership Probe:100 Database:ABC

errno:

0x0FFFFFFFFFFF7AF0 : 0x00000001 ....

PID:1355876 TID:1 Node:000 Title: Path/Filename

/home/db2inst1/sqllib/function/routine/sqlproc/ABC/DB2INST1/tmp/

2002-10-05-13.47.40.166289 Instance:db2inst1 Node:000

PID:1355876(db2agent (ABC) 0) TID:1 Appid:OC10103F.OD12.017302185202

PSM - SQL Procedure psm_ctrl::psm_init_backend Probe:230 Database:ABC

DIA8402C A disk error has occurred.

ZRC=0x860F0004

PID:1355876 TID:1 Node:000 Title: SQL procedure initialization:

0x09000000031213BC : 696E 7374 616E 6365 206F 776E 6572 2064 instance owner d

0x09000000031213CC : 6F65 7320 6E6F 7420 6265 6C6F 6E67 2074 oes not belong t

0x09000000031213DC : 6F20 6665 6E63 6564 2075 7365 7227 7320 o fenced user's

0x09000000031213EC : 7072 696D 6172 7920 6772 6F75 70 primary group

答:在 Unix 平台下的 DB2 存储过程对于实例用户和受防护用户之间的关系有一个约束,即 DB2 实例用户必须同时是受防护用户的主组中的一个用户。上述问题的发生就是由于在系统上,实例用户未加入至受防护用户的主组中,从而引发了存取权限不够的问题所导致的,而并非真的发生了如日志中所报的磁盘错误。解决这一问题的方法很简单,只要将实例用户加入该主组即可。但有时用户会发现,即使已将用户加入到指定组,问题仍然存在,这时还应检查一下实例用户所加入的组是否是实例用户所对应的受防护用户的主组,即检查一下加入的组是否正确。

要找到实例用户所应的受防护用户以及受防护用户的主组,可用如下方法:

1. 转入实例用户 Home 路径下的 sqllib/adm 路径

2. 执行命令:ls -l .fenced,会得到类似如下输出:

-r--r--r-- 1 db2fencj db2fgrp2 0 Jul 30 09:57 .fenced

3. 输出中表明,该文件所属的用户(db2fencj)即为受防护用户,所属的组(db2fgrp2)即为受防护用户的主组

继而,用户便可验证实例用户是否被加入到了正确的组中,如果结果正确,便可以解决上述问题。

上一篇:讲解IBM DB2数据库的常用日期操作函数 人气:1243
下一篇:IBM DB2跨平台数据库迁移步骤和注意事项 人气:895
浏览全部DB2的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐