ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
エラーの状況
CREATE TABLE users (
id VARCHAR(36) NOT NULL AUTO_INCREMENT,
name VARCHAR(100),
PRIMARY KEY (id)
);
-- ERROR 1063 (42000): Incorrect column specifier for column 'id'
MySQL の AUTO_INCREMENT は整数型 (TINYINT / SMALLINT / MEDIUMINT / INT / BIGINT) 限定です。VARCHAR / CHAR には付けられません。
原因と対処
原因 1: 整数以外の型に AUTO_INCREMENT
-- ダメな例
CREATE TABLE users (
id VARCHAR(36) NOT NULL AUTO_INCREMENT, -- ← VARCHAR + AUTO_INCREMENT は不可
...
);
-- 修正案 1: INT に変える
CREATE TABLE users (
id BIGINT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id),
...
);
-- 修正案 2: UUID を使う(AUTO_INCREMENT は使わず手動セット)
CREATE TABLE users (
id CHAR(36) NOT NULL DEFAULT (UUID()), -- MySQL 8 では DEFAULT (UUID()) が使える
...
PRIMARY KEY (id)
);
原因 2: 主キー未定義で AUTO_INCREMENT
-- ダメな例
CREATE TABLE users (
id BIGINT AUTO_INCREMENT,
name VARCHAR(100)
-- ← PRIMARY KEY 宣言なし
);
-- ERROR
-- 修正
CREATE TABLE users (
id BIGINT AUTO_INCREMENT,
name VARCHAR(100),
PRIMARY KEY (id) -- ← 追加
);
-- またはインラインで
CREATE TABLE users (
id BIGINT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100)
);
原因 3: 1 テーブルに複数 AUTO_INCREMENT
-- ダメな例
CREATE TABLE orders (
id BIGINT AUTO_INCREMENT,
order_no BIGINT AUTO_INCREMENT, -- ← 2 つ目は不可
PRIMARY KEY (id)
);
-- ERROR: Incorrect table definition; there can be only one auto column
-- AUTO_INCREMENT は 1 テーブルに 1 カラムだけ
-- 別の連番が欲しい場合は別の方法(トリガ / シーケンステーブル)
AUTO_INCREMENT が使える型
| 型 | 範囲 | 用途 |
|---|---|---|
| TINYINT | -128〜127 / 0〜255 | 小規模カウンタ(255 以下) |
| SMALLINT | -32K〜32K / 0〜65K | 中小規模 |
| MEDIUMINT | 16M / 16M | 中規模 |
| INT | 21億 / 42億 | 標準的 |
| BIGINT | 9.2 京 / 18 京 | 大規模・将来安全 |
推奨: BIGINT(将来オーバーフローしない)+ UNSIGNED(負の数不要なら範囲倍に)
CREATE TABLE users (
id BIGINT UNSIGNED NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)
);
UUID を使う場合
整数連番ではなく UUID を主キーにしたい場合は AUTO_INCREMENT は使えません:
-- 方法 1: アプリ側で UUID 生成(推奨)
CREATE TABLE users (
id CHAR(36) NOT NULL, -- UUID v4 形式 (32 hex + 4 hyphens)
name VARCHAR(100),
PRIMARY KEY (id)
);
-- Java
INSERT INTO users (id, name) VALUES (?, ?);
// id = UUID.randomUUID().toString();
-- 方法 2: MySQL 8 で DEFAULT (UUID())
CREATE TABLE users (
id CHAR(36) NOT NULL DEFAULT (UUID()),
name VARCHAR(100),
PRIMARY KEY (id)
);
INSERT INTO users (name) VALUES (?); -- id 自動セット
-- 方法 3: BINARY(16) で省スペース化
CREATE TABLE users (
id BINARY(16) NOT NULL DEFAULT (UUID_TO_BIN(UUID())),
name VARCHAR(100),
PRIMARY KEY (id)
);
-- 取得時は BIN_TO_UUID(id) で文字列化
JPA エンティティとの対応
// AUTO_INCREMENT (BIGINT)
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
}
// UUID (CHAR(36))
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.UUID) // Hibernate 6+
@Column(columnDefinition = "CHAR(36)")
private UUID id;
}
関連エラー
Multiple primary key defined: 主キーを複数指定(複合キーなら PRIMARY KEY (...) を 1 つに)Table definition; there can be only one auto column: AUTO_INCREMENT が複数Duplicate entry for key PRIMARY: AUTO_INCREMENT のリセットや手動 ID 指定で重複BLOB/TEXT column ... used in key specification: TEXT に PRIMARY KEY を付けた
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- 1071 Specified key was too long; max key length is 767 bytes
- ERROR 1063 (42000): Incorrect column specifier for column '~'
- mysqld: Can't change dir to '...\MySQL\MySQL Server X.X\data\' (OS errno 2 - No such file or directory)
- Install/Remove of the Service Denied!
- Datetime 型が NULL に見える
- Warning: World-writable config file '/etc/mysql/my.cnf' is ignored
- ERROR 1698 (28000): Access denied for user 'root'@'localhost'
- Exception: Wrong MySQL configuration
- [Warning] TIMESTAMP with implicit DEFAULT value is deprecated.
- ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
- ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
- Incorrect column specifier for column 'カラム名'
- BLOB/TEXT column 'description' used in key specification without a key length
- ERROR: /bin/sh: mysql_config: コマンドが見つかりません
- Host '...' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'
- CSVエクスポート時に「ERROR 1045 (28000): Access denied for user 'username'@'localhost'」エラーが表示される
- Cannot execute statement: impossible to write to binary log since BINLOG_FORMAT = STATEMENT
- 1
- 1
- 1)
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1"'`--
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1)
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1"'`--
- 1
- 1
- SQLSTATE[22007]: Invalid datetime format: 1366 Incorrect string value: ~
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?