DB2删除模式下对象

环境:  Windows XP,   DB2 V9.7

DB2有删除模式的语句drop schema xxx restrict, 但只能在该模式没有对象的情况下才能执行。因此就有一个存储过程ADMIN_DROP_SCHEMA用于删除模式下的对象和模式本身。其语法为:ADMIN_DROP_SCHEMA(schemadropmode,errortabschemaerrortab)。例如: db2 call admin_drop_schema(‘DB2ADMIN’,NULL, ‘ERRORSCHEMA’, ‘ERRORTABLE’),  这个过程不支持删除nicknames ,packages ,typed tables

SQL1219N 因为未能分配专用虚拟内存,所以请求失败。 SQLSTATE=57011

环境: db2 v9.7 , windows xp

今天不知怎得,连接DB2数据库一直报这个错误“SQL1219N  因为未能分配专用虚拟内存,所以请求失败。  SQLSTATE=57011”,开始一直以为是内存不够用,于是重启电脑,并将其它的进程关掉。仍无法解决问题。在网上找了半天,发现说有个全局变量DB2_EXTSECURITY可以解决这个问题。于是的命令行输入: db2set  DB2_EXTSECURITY=NO ,重新启动数据库即可连接。

 

这个变量DB2_EXTSECURITY描述如下:

DB2 version 8.2 on Windows contains a new security feature that
controls access to DB2 system files, registry keys, and network
shares. The security feature is enabled by default by setting
the DB2 registry variable DB2_EXTSECURITY=YES during
installation of DB2. Attempts to use the DB2 product under a
userid that is not part of either the DB2USERS or DB2ADMNS group
on Windows, will result in a variety of symptoms, including, but
not limited to the following:

– SQL1224N – database agent could not be started.
– Various permissions errors using the DB2 CLP.
– DB2 processes that unexplainably abend.

db2 设置语句结束符

环境: db2 9.5 , windows xp

设置方法: 在cmd命令行中输入 db2set db2options=td;

其中td为设置的结束符的标识,而;为设置好的结束符。

 

********************************************************************************

 

在db2环境下写存储过程,函数和触发器时,由于这些语句中;为语句终止符,所以需要重新设置语句终止符。方法如下:

在语句开始前输入 –#SET TERMINATOR @,这样将这些单元的终止符设置为@。

语句结束后输入 –#SET TERMINATOR ;

数据库查询配置值

Oracle :    show parameter 配置名

DB2 :    ! db2 get db cfg for 数据库名 | find /i “配置名”

SQL Server :  select * from sys.configuration  (sql server 2005)

PostgreSQL :  show all 或 show 参数名

MySQL :   show variables 或 show variables like ‘参数名%’

搭配私人和公共的IM平台

环境:Ubuntu 12.04, Pidgin, pidgin-lwqq, Spark, ejabberd

由于个人经常在Ubuntu平台上操作,而这个平台上基于XMPP协议和跨平台比较好用的客户端有pidgin和spark,因而可以自己搭配私人的IM的平台。同时要跟外部QQ通信,因而希望其支持。

具体步骤如下:

安装ejabberd

1. 安装erlang
sudo apt-get install erlang

2. 安装ejabberd
sudo apt-get install ejabberd

3. 修改ejabberd.cfg,增加管理员用户,密码和主机名
vi /etc/ejabberd/ejabberd.cfg

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Options which are set by Debconf and managed by ucf

%% Admin user
{acl, admin, {user, “jerry”, “hq”}}.

%% Hostname
{hosts, [“hq”]}.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

4. 修改hosts,增加ip与主机名对应
sudo vi /etc/hosts

192.168.56.101  hq

5. 修改ejabberd管理员密码
sudo ejabberdctl register jerry hq jerry

6. 重启ejabberd服务
sudo service ejabberd restart

****************************************************************************************************************************

安装pidgin和pidgin-lwqq

1.  安装pidgin
sudo apt-get install pidgin

2. 安装pidgin-lwqq
sudo add-apt-repository ppa:lainme/pidgin-lwqq
sudo apt-get update
sudo apt-get install pidgin-lwqq

****************************************************************************************************************************

启动并使用pidgin

1. 启动pidgin
jerry@hq:~$ pidgin

2. 与QQ通信
增加帐户,”Basic”项目栏protocol指定为WebQQ,输入QQ的用户名和密码即可

3. 私人通信
增加帐户,”Basic”项目栏protocol指定为XMPP,”Advanced”项目栏上输入主机和端口(例: hq, 5222, 此信息是ejabberd所提供的)

至止,可以跨平台跨各种通信协议来使用自己的和外部的即时通信了

Octave 数值计算

环境: Ubuntu 12.04 ,  Octave 3.8.2

Octave是一个旨在提供与Matlab语法兼容的开放源代码科学计算数值分析的工具,它支持向量和矩阵计算,方便写数学表达式。

安装步骤如下:
wget ftp://ftp.gnu.org/gnu/octave/octave-3.8.2.tar.gz
tar xvf octave-3.8.2.tar.gz
cd octave-3.8.2
./configure
make
sudo make install

进入命令行:
jerry@hq:~$ octave
warning: docstring file ‘/usr/local/share/octave/3.8.2/etc/built-in-docstrings’ not found
No protocol specified
GNU Octave, version 3.8.2
Copyright (C) 2014 John W. Eaton and others.
This is free software; see the source code for copying conditions.
There is ABSOLUTELY NO WARRANTY; not even for MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  For details, type ‘warranty’.

Octave was configured for “x86_64-unknown-linux-gnu”.

Additional information about Octave is available at http://www.octave.org.

Please contribute if you find this software useful.
For more information, visit http://www.octave.org/get-involved.html

Read http://www.octave.org/bugs.html to learn how to submit bug reports.
For information about changes from previous versions, type ‘news’.

octave:1>

octave:28> version
ans = 3.8.2
octave:29> pi
ans =  3.1416
octave:30> A
A =

1   2
3   4

octave:31>

MySQL 导出导入二进制文件

环境:winXP, mysql, Redhat

在一次从RHEL 5 dump整个数据库并在winXP下恢复,由于有一个表包含图片数据,导致“’”分隔符被吞噬(由于二进制编码的问题,引号分隔符被当作了数据的一部分),从而使得数据不能被正常导入。造成整个数据库无法导入。

解决方法:1.  使用select [binary_column] into dumpfile ‘dump_dir’ from [table_name], 然后在命令行中insert into table(binary_column) values(load_file(‘dump_dir’)); 由于只能导出单行。用起来相当麻烦。

2.  使用select col1, col2, … , hex([binary_column])  into outfile ‘dump_dir’ from [table_name], 然后在命令行中导入load data infile ‘dump_dir’ into table [table_name], 最后将之前转化为十六制的字段再转为二进制 update [table_name] set [binary_column] = unhex([binary_column]),这样就完成导入过程。

MySQL 与OS交互

环境:RHEL 5,  MySQL 5

一直都以为mysql 不能像oracle/db2/sql server那样在存储过程或函数中执行操作命令,今天在网上发现有个lib_mysqludf_sys可以实现这种功能。这个库文件在http://www.mysqludf.org/lib_mysqludf_sys/index.php上。

解压后其中有一个库文件是lib_mysqludf_sys.so,将其中放到mysql的 –plug-dir目录下(ps -ef | grep mysql可以查到plug-dir 或 在mysql命令行中查询select @@plugin_dir;),重新启动mysql服务。进入mysql命令行中,选择mysql数据库,执行CREATE FUNCTION sys_eval RETURNS STRING SONAME ‘lib_mysqludf_sys.so’; 这样就可以执行OS命令了,mysql>select sys_eval(‘ls’);

MySQL一个有意思的问题

DELIMITER $$
DROP PROCEDURE IF EXISTS `p3` $$
CREATE PROCEDURE p3()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE table_name VARCHAR(255);
DECLARE stmt varchar(200);
DECLARE cur1 CURSOR FOR select table_name from information_schema.tables;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
OPEN cur1;
REPEAT
FETCH cur1 INTO table_name;
select table_name;
UNTIL done = 1
END REPEAT;
CLOSE cur1;
END $$
DELIMITER ;
查询出来的结果都为空, 最后发现变量table_name与游标定义中的table_name重复,修改变量table_name为其它的名字。 但具体内在的发生机制还不太清楚。