Tags: utf-8

mysqlの設計をするときに改めてカラムタイプについて考えてみた。
いまさらという感じでもあるが。。。

例えばブログのタイトル。
大体、100文字あれば十分という感じがする。
でもUTF-8の場合、日本語はほぼ一文字あたり3バイト(ときに4バイト)になるため
文字数x3から4を見積もるため、100文字の場合は300から400バイトを割り当てることになる。
でもvarcharの最大データ長は255だから、日本語で100文字のタイトルを設定するとなると
カラムタイプをtextにしないといけなくなる。タイトルなのに。
そんなバカな!

逆に200byteで考えておけば50~60文字のタイトルが格納される。
もちろん半角英数字が入る場合はもっと長くなる。
そうするとinputタグにmaxlength仕掛けても、それってユーザビリティ悪い気もする。
ajaxで文字列のバイト数を計算して、キーを叩くたびに計算して
オーバーしたらエラーっていうのがスマートかも。

参考:

Code:

echo strlen(bin2hex($str))/2

http://www.cpa-lab.com/tech/0144
http://zombiebook.seesaa.net/article/33192046.html

はじめまして。Takeshiといいます。今年の四月から、恵比寿の小さな会社でウェブSE兼プログラマーとして働き始めました。主にLAMP環境でウェブサービスやウェブサイトの構築をやっています。社会人なりたてということもあり、右も左もわからない状況ですが、日々感じたことや、覚えたことなどをメモっていきたいと思います。コメントやトラックバックなどいただけると、とても嬉しいです!それでは、よろしくお願いいたします。

2月 2012
 << <   > >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29      

検索

XMLフィード

blogging software