7月
27
2009
0

[さくらインターネット]大きなファイルをデータベースにインポートする
このエントリをはてなブックマークに追加このエントリをdel.icio.usに追加このエントリをLivedoor Clipに追加このエントリをYahoo!ブックマークに追加このエントリをFC2ブックマークに追加このエントリをNifty Clipに追加このエントリをPOOKMARK. Airlinesに追加このエントリをBuzzurl(バザール)に追加このエントリをChoixに追加このエントリをnewsingに追加

さくらインターネットのphpmyadminからだと、データベースのインポートの際に8MBの制限があり、約12万行ある郵便番号-住所データ(utf-8保存で約26MB)がインポートできずに困ってました。

ググるとダンプしたデータをSSHで実行する方法が見つかったのでやってみたところ…できました!

参考にしたのは「さくらインターネット 質問にマジレスするスレ Part19」スレ

方法

まずはSSHでさくらインターネットのサーバにログイン *1
ちなみに僕はpoderosaってクライアント使ってます。(ほとんど使えないわないけど)
で、以下のコマンド


-h mysql****.db.sakura.ne.jp -u アカウント名 -p DB名(アカウント名と同じ) < SQLファイルの相対パス

処理が完了するまではかなり時間がかかりましたが、無事取り込むことができました。

  1. 詳しい方法はオンラインヘルプに書いてあるよね []
Written by suzukenn in: 記事 | タグ:
7月
15
2009
0

[CakePHP]Session::setFlash()したメッセージをオリジナルのレイアウトで表示する
このエントリをはてなブックマークに追加このエントリをdel.icio.usに追加このエントリをLivedoor Clipに追加このエントリをYahoo!ブックマークに追加このエントリをFC2ブックマークに追加このエントリをNifty Clipに追加このエントリをPOOKMARK. Airlinesに追加このエントリをBuzzurl(バザール)に追加このエントリをChoixに追加このエントリをnewsingに追加

先ほどのエントリーに続いてSession::setFlash()だとかの話。
先ほどのエントリー、問題があったので一部修正させていただきましたm_ _m)

調べてみると、Session::setFlash()は第2引数でlayoutを指定できるらしい。。知らなかった…orz
で、使い方ですが、

コントローラで以下のようにレイアウトを指定してSession::setFlash();する。

// Session::setFlash($message, $layout = 'default', $params = array(), $key = 'flash');
$this->Session->setFlash("エラーですよ\n大変なことです", "flash/mylayout");

上記の例だと、レイアウトをflash/mylayoutで指定しているので、
/app/views/layouts/flash/mylayout.ctpを作成して読み込ませます。

肝心のレイアウトファイルからsetFlashしたメッセージを表示する方法ですが、
$content_for_layoutで表示できます。

サンプル:/app/views/layouts/flash/mylayout.ctp

<div class="message">
    <p class="attention">
        <?PHP echo nl2br($content_for_layout); ?>
    </p>
    <p class="inquiry">
        詳細は<?PHP echo $html->link("お問い合わせフォーム", "/inquiry"); ?>よりお問い合わせください。
    </p>
</div>

この方法だと、上記のように$content_for_layoutに対してnl2brしてあげればいいだけですし、
setFlashした内容を表示するブロックに、お問い合わせフォームのリンクを置いたり、ヘルプをセットしたり、ツールチップをセットしてみたり、デザインに凝ってみたり好き勝手できますよね^^

setFlashを調べてたら思わぬ収穫があってラッキーでした。
きっとCakePHPにはまだまだたくさん「知ってれば得をすること」があるんでしょうね。

Written by suzukenn in: メモ | タグ: ,
7月
15
2009
0

[CakePHP]$session->flash()内で改行できるようにする
このエントリをはてなブックマークに追加このエントリをdel.icio.usに追加このエントリをLivedoor Clipに追加このエントリをYahoo!ブックマークに追加このエントリをFC2ブックマークに追加このエントリをNifty Clipに追加このエントリをPOOKMARK. Airlinesに追加このエントリをBuzzurl(バザール)に追加このエントリをChoixに追加このエントリをnewsingに追加

コントローラで$this->Session->setFlash();でメッセージをセットすると、ビューの$session->flash();で出力されますよね?
でも、改行ができなくて困る。と思ったことありません?

というわけで、簡単に改行できる方法をメモ。
最初に書いた方法だと$this->Session->setFlash();の第2引数、$layoutを指定したときに問題があるので修正しました。適当なこと書いてごめんなさいm_ _m

  1. /cake/libs/view/helpers/session.phpを/app/views/helpersにコピー
  2. session.phpのflash()メソッドの該当箇所を下記のように修正。
    if ($flash['layout'] == 'default') {
        if (!empty($flash['params']['class'])) {
            $class = $flash['params']['class'];
        } else {
            $class = 'message';
        }
        $out = '<div id="' . $key . 'Message" class="' . $class . '">' . $flash['message'] . '</div>';
        // ↑この行を↓のように修正
        $out = '<div id="' . $key . 'Message" class="' . $class . '">' . nl2br($flash['message']) . '</div>';
    } elseif ($flash['layout'] == '' || $flash['layout'] == null) {
        //  省略
    } else {
        // 省略
    }
    // ↓
    
  3. あとはコントローラから$this->Session->setFlash();する際、改行を挟みたい箇所に\nを入れるだけ。

ちなみに$this->flash();に、上記と同じ方法で改行を入れる場合は、/app/views/layouts/flash.ctpの該当箇所を

<?php echo $message; ?>
// ↓以下に修正
<?php echo nl2br($message); ?>

にしてやればOK

もっと簡単な方法、効率的な方法があれば教えていただけると嬉しいです^^

Written by suzukenn in: メモ | タグ: ,

| I have been indebted to Aeros Theme. | Background image owner is NASA.