データ型 / char と varchar の違い(2)

la mitad del mundo / Quito, Ecuador

char 固定長
varchar 可変長

つまり

char (4)

varchar(4)
だと

・char のカラムはどんな値が入っても4バイト使う
・varcharは値の分とカラムの長さの情報分1バイトを使う

なので、

‘ab’を格納すると 
char は4バイト使って
varcharは3バイトしか使わない。

‘abcd’を格納すると
char のカラムは4バイト使うけど、
varchar のカラムは5バイト使うことになる。

..::結論::..
格納するデータのサイズが決まってる場合はchar
決まってない場合はいつでもvarchar

で良いのかな?

CSSの覚え書き ボックスのセンタリング

ボックスの中央寄せ

↓でmozilla とchromeはOK

div#id1{
margin-left: auto;
margin-right: auto;
}

IE6ではダメなのでその外側に

div#id2{
text-align: left;
}

とするとOK。

border-width: 3px;
border-color: #696969;
border-top-style:none;
border-bottom-style:none;
border-left-style:solid;
border-right-style:solid;

salinas, ecuador

日付データの正規表現 mb_ereg

csvファイル
‘test.csv
“****,****,3月25日 23時44分,****,……”
のなかの日付のとこを
2009-3-25
とかにする

$fp = fopen(“/tmp/test.csv“,”r+”)or die(“can not open”);
$count= 0;

while(!(feof($fp))){
$buf = fgets($fp, 1024);
$buf = chop($buf);

$data = split(“,”,$buf);

$hiduke[$count] = $data[4];

$pat = “([0-9]{1,2})[月]{1}([0-9]{1,2})[日]?”;

$mb = mb_ereg($pat,$hiduke[$count],$reg);

Marcos、覚えてる?

icapui/Ceará

MySQLへcsvデータのインポート/ユーザ変数

基本は↓

LOAD DATA INFILE ‘/tmp/data.csv’ INTO TABLE table01

デフォルトでは

\t (タブ)がフィールドの区切り
\n が改行

csvファイルを読み込むときは

FIELDS TERMINATED BY ‘,’

でカンマをフィールドの区切りに指定する。

行の区切りはテキストエディタによって違うので
LINES TERMINATED BY ‘\r\n’
とか
LINES TERMINATED BY ‘\r’
とか指定する。

LINES STARTING BY ‘xxx’(プリフィックス)

とかすると
xxx”abc”,1
something xxx”def”,2
“ghi”,3

abc 1
def 2

となる。

ユーザー変数の使い方

インプット ファイル内のフィールドの順番が、テーブル内のカラムの順番と異なる場合は、カラム リストも指定しなければいけません。
カラム リストはカラム名かユーザ変数のどちらかを含みます。ユーザ変数を利用すると、カラムに結果を割り当てる前に SET 条項で値を変換する事ができます。

SET 条項の中のユーザ変数は、いくつかの方法で利用する事ができます。次の例は、t1.column1 の値に対して直接最初のインプット カラムを利用し、そして2番目のインプット カラムを t1.column2 の値に利用される前に、分割操作に影響されるユーザ変数に割り当てます。

LOAD DATA INFILE ‘file.txt’
INTO TABLE t1
(column1, @var1)
SET column2 = @var1/100;

SET 条項は、インプット ファイルから派生した物ではない値を提供する事ができます。次のステートメントは、現在の日付と時間に column3 を設定する事ができます。

LOAD DATA INFILE ‘file.txt’
INTO TABLE t1
(column1, column2)
SET column3 = CURRENT_TIMESTAMP;

インプット値をユーザ変数に割り当て、変数をテーブル カラムに割り当てない事で、インプット値を廃棄する事ができます。

LOAD DATA INFILE ‘file.txt’
INTO TABLE t1
(column1, @dummy, column2, @dummy, column3);