2009年9月18日金曜日

データベースの自動起動

1. サービス
windowsのサービスでDBが立つヤツとマネジメントサーバが立つヤツを自動にする

2. レジストリ
レジストリの
HKEY_LOCAL_MACHINE > SOFTWARE > ORACLE > HOME0 の
ORACLE_(SID)_AUTOSTART を TRUE にする

3. OS認証
sqlnet.oraに
SQLNET.AUTHENTICATION_SERVICES =(NONE)
と記述

ORA_OEMREP_SHUTDOWN_TIMEOUT

2009年9月9日水曜日

MySQL の文字列関連の関数

■文字列連結
・文字列結合は concat() を使用する。
select concat(123456, 789012);

+------------------------+
| concat(123456, 789012) |
+------------------------+
| 123456789012 |
+------------------------+

select concat('123456', 789012);

+--------------------------+
| concat('123456', 789012) |
+--------------------------+
| 123456789012 |
+--------------------------+

select concat('123456', '789012');

+----------------------------+
| concat('123456', '789012') |
+----------------------------+
| 123456789012 |
+----------------------------+

select concat(key1, data1) from testm;

+---------------------+
| concat(key1, data1) |
+---------------------+
| a0011 |
| a0111 |
| b00210 |
| c003100 |
+---------------------+

■char 文字変換

・char() 関数は、コードに該当する ASCII 文字を返す。
この例では、「1」と言う文字が返る。

select char(49);

+----------+
| char(49) |
+----------+
| 1 |
+----------+

■ascii コード変換

・ascii() 関数は、文字に該当する ASCII コードを返す。
この例では、「49」と言う数字が返る。

select ascii('1');

+------------+
| ascii('1') |
+------------+
| 49 |
+------------+

■小文字化

・lower() 関数は、英字を小文字にして返す。

select lower('ABC012');

+-----------------+
| lower('ABC012') |
+-----------------+
| abc012 |
+-----------------+

■大文字化

・upper() 関数は、英字を大文字にして返す。

select upper('abc012');

+-----------------+
| upper('abc012') |
+-----------------+
| ABC012 |
+-----------------+

■左文字埋め

・lpad() 関数は、文字列の左に指定文字を埋めて指定数切り出します。
(切り出し指定数になるまで繰り返し埋めます。)

select lpad('abc', 5, '0');

+---------------------+
| lpad('abc', 5, '0') |
+---------------------+
| 00abc |
+---------------------+

select lpad('abc', 5, '012');

+-----------------------+
| lpad('abc', 5, '012') |
+-----------------------+
| 01abc |
+-----------------------+

・指定文字省略値はないようで、指定しないとエラーになる。

select lpad('abc', 5, ' ');

+---------------------+
| lpad('abc', 5, ' ') |
+---------------------+
| abc |
+---------------------+

■右文字埋め

・rpad() 関数は、文字列の右に指定文字を埋めて指定数切り出します。
(切り出し指定数になるまで繰り返し埋めます。)

select rpad('abc', 5, '0');

+---------------------+
| rpad('abc', 5, '0') |
+---------------------+
| abc00 |
+---------------------+

select rpad('abc', 5, '012');

+-----------------------+
| rpad('abc', 5, '012') |
+-----------------------+
| abc01 |
+-----------------------+

・指定文字省略値はないようで、指定しないとエラーになる。

select rpad('abc', 5, ' ');

+---------------------+
| rpad('abc', 5, ' ') |
+---------------------+
| abc |
+---------------------+

■左空白削除

・ltrim() 関数は、文字列の左側の空白を除去します。

select ltrim(' abc');

+------------------------+
| ltrim(' abc') |
+------------------------+
| abc |
+------------------------+

■右空白削除

・rtrim() 関数は、文字列の右側の空白を除去します。

select ltrim('abc ');

+------------------------+
| ltrim('abc ') |
+------------------------+
| abc |
+------------------------+

■左右空白削除

・trim() 関数は、文字列の左右の空白を除去します。

select trim(' abc ');

+---------------------------------+
| trim(' abc ') |
+---------------------------------+
| abc |
+---------------------------------+

■文字列置き換え

・replace() 関数は、文字列の置き換えをする。
「a0a1a2」中の a0 を b1 に置き換える場合、次のようにします。

select replace('a0a1a2', 'a0', 'b1');

+-------------------------------+
| replace('a0a1a2', 'a0', 'b1') |
+-------------------------------+
| b1a1a2 |
+-------------------------------+

・translate() 関数は、ないようである。

■文字列切り出し

・substring() 関数は、文字列の切り出しをする。

select substring('abc012', 3, 2);

+---------------------------+
| substring('abc012', 3, 2) |
+---------------------------+
| c0 |
+---------------------------+

・開始位置以降、最後まで切り出す場合は、切り出す文字数を省略できる。

select substring('abc012', 3);

+------------------------+
| substring('abc012', 3) |
+------------------------+
| c012 |
+------------------------+

■文字列検索

・locate() 関数は、文字列の検索を行う。

select locate('c0', 'abc012');

+------------------------+
| locate('c0', 'abc012') |
+------------------------+
| 3 |
+------------------------+

select locate('c0', 'abc012c0', 4);

+-----------------------------+
| locate('c0', 'abc012c0', 4) |
+-----------------------------+
| 7 |
+-----------------------------+

■文字列の長さ

・length() 関数は、文字列の長さを返す。

select length('abc012');

+------------------+
| length('abc012') |
+------------------+
| 6 |
+------------------+

■文字列繰り返し

・repeat() 関数は、文字列を繰り返し返す。

select repeat('abc012', 2);

+---------------------+
| repeat('abc012', 2) |
+---------------------+
| abc012abc012 |
+---------------------+

■数値から文字列へ変換 (数値フォーマット、書式変換)

・文字列としての結合は concat() を使用する。

select concat(123456, 789012);

+------------------------+
| concat(123456, 789012) |
+------------------------+
| 123456789012 |
+------------------------+

select concat('123456', 789012);

+--------------------------+
| concat('123456', 789012) |
+--------------------------+
| 123456789012 |
+--------------------------+

select concat('123456', '789012');

+----------------------------+
| concat('123456', '789012') |
+----------------------------+
| 123456789012 |
+----------------------------+

・三桁毎にカンマを付けるには、次のようにする。

select format(123456, 0);

+-------------------+
| format(123456, 0) |
+-------------------+
| 123,456 |
+-------------------+

select format(123456, 2);

+-------------------+
| format(123456, 2) |
+-------------------+
| 123,456.00 |
+-------------------+

■文字列から数値へ変換

・勝手にやるみたいです。

select '0123' + 100;

+--------------+
| '0123' + 100 |
+--------------+
| 223 |
+--------------+

select '0123' + '100';

+----------------+
| '0123' + '100' |
+----------------+
| 223 |
+----------------+

■型変換

・cast() 関数は、ANSI 規程の変換関数です。

select cast(concat('123', '456') as signed);

+--------------------------------------+
| cast(concat('123', '456') as signed) |
+--------------------------------------+
| 123456 |
+--------------------------------------+

select cast(concat('-123', '456') as unsigned);

+-----------------------------------------+
| cast(concat('-123', '456') as unsigned) |
+-----------------------------------------+
| 18446744073709428160 |
+-----------------------------------------+

select cast(123 + 100 as char);

+-------------------------+
| cast(123 + 100 as char) |
+-------------------------+
| 223 |
+-------------------------+

2009年9月3日木曜日

eclipseでphp

1 IISを止める
[1]
2 xamppをインストール
http://www.apachefriends.org/jp/xampp-windows.html
ダウンロードのインスートラを落とす
xampp-win32-1.7.1-installer.exe
実行してインストール
[1-]

3 apacheを設定(ユーザーフォルダ)
C:\xampp\apache\conf\httpd.conf を編集

#LoadModule userdir_module modules/mod_userdir.so

#コメントアウトをはずしました
LoadModule userdir_module modules/mod_userdir.so

C:\xampp\apache\conf\extra\httpd-userdir.conf を編集

UserDir "My Documents/My Website"

#コメントアウトして書き換え ここから
#UserDir "My Documents/My Website"
UserDir "D:/httpd/*/public_html"
#コメントアウトして書き換え ここまで






apacheを再起動

4 phpを設定
phpinfoをみる
zend debuggerをダウンロード
http://downloads.zend.com/pdt/server-debugger/
ZendDebugger-5.2.15-cygwin_nt-i386.zip

[Zend]
zend_extension_ts = "C:\xampp\php\zendOptimizer\lib\ZendExtensionManager.dll"
zend_extension_manager.optimizer_ts = "C:\xampp\php\zendOptimizer\lib\Optimizer"
zend_optimizer.enable_loader = 0
zend_optimizer.optimization_level=15
;zend_optimizer.license_path =
; Local Variables:
; tab-width: 4
; End:

;コメントアウト ここから
;zend_extension_ts = "C:\xampp\php\zendOptimizer\lib\ZendExtensionManager.dll"
;zend_extension_manager.optimizer_ts = "C:\xampp\php\zendOptimizer\lib\Optimizer"
;zend_optimizer.enable_loader = 0
;zend_optimizer.optimization_level=15
;コメントアウト ここまで
;追加 ここから
zend_extension_ts="C:\xampp\php\zendDebugger\php-5.2.x\ZendDebugger.dll"
zend_debugger.allow_hosts=127.0.0.1,192.168.0.0/24
zend_debugger.expose_remotely=always
;追加 ここから

5 eclipseを入れて設定
eclipseをダウンロード
http://mergedoc.sourceforge.jp/

ワークスペースを決める

http://journal.mycom.co.jp/column/ide/006/index.html
ウィンドウ>設定>php>PHP実行可能ファイル>追加

PHP サーバー>編集>パス・マッピング>追加