イメージ
 Kindle Paperwhiteが故障 2023年の3月購入なので、1年の保証期間はとっくに過ぎている。 状況は、画面右端が充電後に表示欠けを起こすようになった。 最初は1cm程度だったのに、いまでは2cm程度表示できず、右端の文字が読めない状況に…。 さて、修理可能なのか不明なので、Amazonに問い合わせすることに…。 チャットで問い合わせを選択すると、すぐに担当者につながった。 日本人の名前ではなかったけれど、とても丁寧な対応でしっかり教育されている感じ。 結果的には、 ・修理対応は行っていない。 ・買い替えるしか手段はない。 しかも、同一機種はすでに無く、後継機種(画面が7インチにUp)しか選択できない。 さて、どうしようかとチャットしながら考えていたら、先方から提案が…。  再度、Kindle端末を購入されるのであれば、15%OFFのギフトを送る(登録)ってくれる。  ご検討くださいとのことだった…。 なるほど…。  いま Kindle端末 を見ると22,980円か〜。さらに15%OFFとなると、19,533円 迷うなぁ…。もうタブレットを使用しちゃおうかとも考えていたので…。 ギフトの期限は無いそうなので、しばらく悩んでみますゎ。

PostgreSQLでEUC_JPのテーブル

今さらEUC_JPって感じだけど

すでにサーバ環境がUTF-8をデフォルトとするようになって、随分経っているので必要となるケースは少ないんだけど、今回はハマりました。

通常であれば、UTF-8でDBを構築していけば、特に問題もなく引っかかるようなところは何もないのだけれど…。
サーバの移行のため、仕方なくEUC_JPを使うことに。

旧データベースは、プログラムもEUC_JPで構築されている。
プログラムの書き換えは動作検証に時間がかかるので、そのまま動かしたい。

まぁPostgreSQLは文字コードを選べるので、問題ないだろうと…。

サーバにPostgreSQLをインストール

これは問題なく、いつも通りapt-getで入れてオシマイ。
何も引っかかるところはありません。

ついでに、phppgadminも入れておく。
これで作業が簡単になる。

旧サーバにも入っているので、確認がしやすいですな。
若干、バージョンが異なっているので、その点だけ要注意と。

さてphppgadminを使ってDBをEUC_JPで作ろうとしたら、上手くいかない。
createdb: database creation failed: ERROR:  encoding EUC_JP does not match locale en_US.UTF-8
見慣れぬエラーですね…。しかもDBは作成してくれない。

何か操作を間違えたのかと、見直すが、特に手順に問題はない。
「ERROR:  encoding EUC_JP does not match locale en_US.UTF-8」でググってみると 、最初に答えが見つかった。

名称未設定:Ubuntu12.04LTSのPostgreSQLでEUC_JPのデータベースを作る」とまんま同じ内容だった。

これによると、
createdb -T template0 -E EUC_JP --locale=C dbname
と、localをCで作りなさいということらしい。

試しに、コンソールから試してみると、確かに文句も言われず作成してくれる。

phppgadminでもできるはず 

この方法は、postgresユーザで作業するコンソール上のコマンドなので、phppgadmin上で異なるユーザで作成したい。

試してみるが、どこに設定すべきか分かりにくい。

何度か試してみると、図のようにすれば思うように作成できることがわかった。

Template→template0を選択(UTF-8の時はtemplate1)
エンコード→もちろんEUC_JP
CollectionとCharacterType→Cで設定

これでOKだった。

ここまでくれば、あとはdumpデータを突っ込んでやればOK。

と思ったら、「サーバが指定されていません」って…。見たことのあるメッセージや!
半年以上経つと、すっかり忘れて同じミスをしでかす。

だからこうやってブログにまとめておく必要があるんだなぁwww

ちゅうことで、php.iniを書き換えて解決とな。


コメント

このブログの人気の投稿

Ubuntu24.04 でGUIが死んだ

WPS Officeで日本語入力ができない

MEGAにも弱点があった?