SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

直近開催のイベントはこちら!

EnterpriseZine編集部ではイベントを随時開催しております

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けの講座「EnterpriseZine Academy」や、すべてのITパーソンに向けた「新エバンジェリスト養成講座」などの講座を企画しています。EnterpriseZine編集部ならではの切り口・企画・講師セレクトで、明日を担うIT人材の育成をミッションに展開しております。

お申し込み受付中!

MySQL事始

MySQL事始 SQL文(5) DDL

第8回


列の追加

 1列だけ追加する場合は、追加する位置をテーブルの先頭か特定の列の後ろが指定できます。明示的に指定しない場合は最後の列の後ろに列が追加されます。

ALTER TABLE テーブル名 ADD [COLUMN] 列名 列の定義 [FIRST | AFTER 既存の列名]

 列の定義には、データ型や必要に応じてデフォルト値、文字コードの指定を行います。

 列名と列の定義の組み合わせを括弧内で指定すると、複数の列をまとめて追加することもできますが、この場合は追加する位置を指定できず、自動的にテーブルの最後に追加されます。

なお、既存の行での追加された列には、追加された列の定義によって格納される値が異なります。

  • デフォルト値が設定されている場合:デフォルト値
  • デフォルト値が設定されておらず、NOT NULLでない場合:NULL
  • デフォルト値が設定されておらず、NOT NULLの場合:該当するデータ型の初期値

3番目の場合、データ型によってどの値が入るかが異なるので注意が必要です。数値型の場合は0が、文字列型の場合には長さゼロの文字列が格納されます。

mysql> CREATE TABLE mini_cont SELECT Name, Population FROM Country;
Query OK, 239 rows affected (0.01 sec)
Records: 239  Duplicates: 0  Warnings: 0

mysql> DESC mini_cont;
+------------+----------+------+-----+---------+-------+
| Field      | Type     | Null | Key | Default | Extra |
+------------+----------+------+-----+---------+-------+
| Name       | char(52) | NO   |     |         |       |
| Population | int(11)  | NO   |     | 0       |       |
+------------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> ALTER TABLE mini_cont ADD Id INT(6) NOT NULL DEFAULT 100;
Query OK, 239 rows affected (0.02 sec)
Records: 239  Duplicates: 0  Warnings: 0

mysql> DESC mini_cont;
+------------+----------+------+-----+---------+-------+
| Field      | Type     | Null | Key | Default | Extra |
+------------+----------+------+-----+---------+-------+
| Name       | char(52) | NO   |     |         |       |
| Population | int(11)  | NO   |     | 0       |       |
| Id         | int(6)   | NO   |     | 100     |       |
+------------+----------+------+-----+---------+-------+
3 rows in set (0.01 sec)

mysql> SELECT * FROM mini_cont LIMIT 2;
+----------------------+------------+-----+
| Name                 | Population | Id  |
+----------------------+------------+-----+
| Afghanistan          |   22720000 | 100 |
| Netherlands          |   15864000 | 100 |
+----------------------+------------+-----+
2 rows in set (0.00 sec)

列の削除

ALTER TABLE テーブル名 DROP [COLUMN] 列名

次のページ
列の変更

この記事は参考になりましたか?

  • Facebook
  • Twitter
  • Pocket
  • note
MySQL事始連載記事一覧

もっと読む

この記事の著者

梶山隆輔(カジヤマリュウスケ)

日本オラクル MySQL Global Business Unit Asia Pacific & Japan担当 MySQLソリューション・エンジニアリング・ディレクターオラクル社において、MySQLのお客様環境への導入支援や製品の技術解説を担当するセールスコンサルタントチームのアジア太平洋地域リーダー。多国籍なM...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

EnterpriseZine(エンタープライズジン)
https://enterprisezine.jp/article/detail/3521 2012/02/10 18:05

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング