パスフレーズ付きの秘密鍵は~/.ssh/にちゃんと置いてあるんだけど あえてそれを使わずにログインしたいときに。 ssh -F ~ test@192.168.1.1 という感じで、-Fオプションつけてニセのコンフィグファイル指定するといける。 うさんくせえですがメモ。
SELECT MAX_POINT INTO max_point FROM TEST WHERE id = 1; 以上のような何の変哲もないSQLだが、max_pointの値が強制的にNULLになる。 MySQLのテーブル名やカラム名は大文字小文字区別するが、 ストアドプロシージャに関しては別らしい。大はまりしました。…
TESTパッケージ内のファンクションを呼び出すには以下のようにしとくのが無難。 set serveroutput on declare arg1 VARCHAR2(200); arg2 VARCHAR2(200); result NUMBER; begin result := TEST.TESTFUNC(arg1, arg2); DBMS_OUTPUT.PUT_LINE(arg1); DBMS_OUTPU…
自分用メモ。 innodb_buffer_pool_size = 120000M //適当 innodb_data_file_path = ibdata1:1G:autoextend:max:200G innodb_autoextend_increment=64 innodb_flush_method = O_DIRECT innodb_log_buffer_size = 20M innodb_flush_log_at_trx_commit = 1 // d…
select COL_NAME from TABLE_NAME where COL_NAME in (select COL_NAME from TABLE_NAME group by COL_NAME having count(*) > 1); お好みでdistinctをつけたりしても風流。
トリガとか設定したいときに。rootユーザで入って($mysql -u root) UPDATE mysql.user SET Super_priv='Y' WHERE user='test_user'; 確認は SELECT user, Super_priv FROM mysql.user WHERE user='test_user'; こんなかんじで。
まあなんとなくそんな気はしてた。 別途貼りつけてやんないとダメ。
MySQLが1005番というエラー番号を一律で返しやがるので。 SHOW ENGINE INNODB STATUS; で直前のFK失敗ログが見れます。メモ。
全てのMySQL照合は PADSPACE タイプの物だと覚えておいてください。これは、MySQLの中の全ての CHAR と VARCHAR 値が後続スペースを無視して比較されるという事を意味します。 後続文字が剥ぎ取られたり、比較がそれらを無視する場合は、もしカラムが固有の…
MySQLの文字列照合はデフォルトでignore caseなのでキー項目にはそれを防ぐためにBINARY句を付与したりしますが、CHECK制約でNOT NULLとか後から付与するとそれがなぜか外れます。(MySQL 5.5)それに気づかずにFKを貼ると文字コードが異なるのでエラーになる…
罠があってマニュアルだと 参照表の中では、外部キーカラムが同じ順番で first カラムとしてリストされているインデックスが存在する必要があります。もしそのようなインデックスが無ければ、自動的に参照表上に作成されます。 http://dev.mysql.com/doc/ref…
'aaa' = 'AAA' なんでPKにすると余裕でduplicate keyしたりする。すげえ。これを防ぐにはDDLで VARCHAR(20) BINARY; などとバイナリ指定しないといけない。めんどくせえー ちなみにテーブル名とかOracleは大文字小文字を区別しないのは有名だけど、 MySQLもm…
MySQLのストアドルーチン(ストアドプロシージャ、ストアドファンクション、トリガ)は Oracleで言うところのSQLCODE,SQLERRM的なエラーコード、メッセージを取得できないhttp://bugs.mysql.com/bug.php?id=11660 SQL実行したらざっくり「ストアドでエラーに…
■システム日付 ・Oracle SYSDATE ・MySQL NOW()■日付型→文字列型変換(YYYY/MM/DD) ・Oracle: TO_DATE(TO_CHAR(SYSDATE), 'YY-MM-DD') ・MySQL: DATE_FORMAT( SYSDATE() , '%Y-%m-%d')■TRUNC(日付) ・Oracle TRUNC(SYSDATE) ・MySQL DATE(SYSDATE())■ADD_MONT…
10gのDBサーバに11gのクライアントからEXPしたりしようとすると ORA-00904: "POLTYP": invalid identifier って出て途中でアボートする。逆(10gでexpしたものを11gにimp)とかは普通にできるので なんつーか割り切った仕様なんですかね。めんどくせえなー
RETURN 文は、値を返すことのできないトリガでは利用不可。すぐさまトリガから出るには、LEAVE 文を使用する。 http://dev.mysql.com/doc/refman/5.1/ja/routine-restrictions.htmlたまたまbreakみたいなRETURNだったからLEAVEで逃げれたけど、 これどうなん…
注意:MySQL 5.1.6以前のバージョンでは、MySQL は CREATE TRIGGER を使用する為に SUPER権限を要求する http://dev.mysql.com/doc/refman/5.1/ja/create-trigger.htmlということで、5.0系だとrootユーザじゃないとトリガが設定できないようです。 え……何その…
id NUMBER(10), name VARCHAR(20), sex CHAR(1)...みたいなテーブルがあり、 iBatis使って全件引っこ抜いたりすると、 HashMapだと当然バラバラのkey, valueだし、TreeMapだと50音順で並んじゃいます。 こんなときはLinkedHashMapにすると良いみたいです。 <select id="selectAllByColumnSorted" resultClass="java.util.LinkedHashMap" parameterClass="String" remapResults="true"> </select>…
sqlplusは前回の履歴とか呼び出せないのがなんとも切ないですよねー。 以下の手順でrlwrap入れると、シェルで履歴呼び出しとかできるようになります。便利。依存ライブラリのインストール $ yum -y install readline-devel (Debian系は $ apt-get install li…
こちらのエントリを参考に。Debian/Ubuntu版。 http://ameblo.jp/hetarelog/entry-10375421106.html基本的には一緒だが、一部ソース修正の必要がある。・必要ライブラリの導入 # apt-get install libncurses5-dev ・ファイル取得、解凍、豪華にするパッチ当…
結論から言うと「ない」。 MySQL の場合、DECIMAL(M,D) 並びに NUMERIC (M,D) は同じで、両方共正確に M 桁の精度を持っています。 http://dev.mysql.com/doc/refman/5.1/ja/precision-math-decimal-changes.htmlまあなんとなくDECIMALの方が一般的に使われ…
mysql > CREATE TABLE hoge ( col1 char(10)) ;みたいな char(10) hoge とかのレコードに対して mysql > INSERT INTO hoge (col1) value ('0 ');としても mysql> SELECT length(col1) from hoge; +--------------+ | length(col1) | +--------------+ | 1 | …
いつも思い出せないので。 $ time (ls -l) >log.log 2>&1 2とか&とかがダメなんですよねー。覚えらんない。
例えば細切れにされたdmpがFTPでいっぱい転送されてくるような場合。 普通に考えて怖いですよね。なので以下のようにして*.dmp.crcを生成。 $ for i in `ls *.dmp` ; do cksum $i > $i.crc; done; 比較するときは $ for i in `ls *.dmp` ; do cksum $i | dif…
とりあえずcx_Oracle動けばいいやって感じの場合のメモ。こっからBasicとSDKを拾ってくる http://www.oracle.com/technetwork/jp/topics/index-099943-ja.html■rpmインストール # rpm -ivh oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.rpm # rpm -i…
Linuxでコマンド実行時間を取るのに便利なtimeコマンドですが、sqlplusとかだと途中で入力受付になってそこで止まってしまって計測できないことがあります。そういう時にヒアドキュメントなんですが、いつも忘れちゃうのでメモ。 $ time sqlplus benchmark/t…
カイジ(第二期)面白いですよね。でも途中から何故か「そもそも、そんなに目って出るもんかしら?」ってことが気になりだしてしまい、それどころじゃありませんでした。数学的に考えると、一回振った場合は確率的に 6/6 * 5/6 * 4/6 = 20 / 36 = 0.555、つま…
Linuxならtimeコマンドで一発なんですが、Windowsだと基本GUIな上に「おいこれいったいいつになったら終わるんだよ」みたいなウィザードが延々と表示されるだけ、というしんどい状況に置かれることが多々あります。しかもそういうソフトに限って予測時間も何…
普通にphpコマンドで流すと通るのにWebから接続できねー!って場合、apacheユーザのパスにORACLE_HOMEとかが通ってない。かといえ、apacheとかPHPとかソースから入れるのはめんどくさい。。。という糞畜生向けに、起動スクリプトに環境変数を直書きするとい…
こんな感じで普通にやると化ける。 >>> s = ['あ', 'い', 'う'] >>> print s ['\xe3\x81\x82', '\xe3\x81\x84', '\xe3\x81\x86'] Python3000にすれば治るよ!とか言われても OSにそのまま入ってる奴つかいたいし……3000とかあやしすぎるし……そんなときは >>> …