質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

4回答

1803閲覧

MySQL テーブル作成時に任意のデータ以外挿入できなくする制約をかけたい

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2017/06/01 01:41

###前提・実現したいこと
MySQLの勉強中です
以下のようなテーブルがあるとき性別のレコード部分に「男」か「女」以外のデータは挿入できないようにしたいです。
ENUM型を使わなくても制約を使用すれば実現可能だと聞いたのでENUM型を使わずに実現したいです

MySQL

1+---------------------------+--------------------+--------+------------------+ 2| 名前 | ニックネーム | 性別 | mail | 3+---------------------------+--------------------+--------+------------------+ 4| hogehoge | piyopiyo | 男 | fuga@aaaaaa.com | 5+---------------------------+--------------------+--------+------------------+

###該当のソースコード
現段階では制約などはつけずにテーブルを作成しています。

MySQL

1mysql> create table test( 2 -> 名前 varchar(255), 3 -> ニックネーム varchar(255), 4 -> 性別 varchar(255), 5 -> mail varchar(255) 6 -> );

###試したこと
制約を調べてCHECK制約を使用しましたがよくよく調べるとMySQLには対応していませんでした

MySQL

1mysql> create table test( 2 -> 名前 varchar(255), 3 -> ニックネーム varchar(255), 4 -> 性別 varchar(255) check(性別 = '男' or 性別 = '女'), 5 -> mail varchar(255) 6 -> );

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報
MySQL5.7を使用中

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

ベストアンサー

設計として一般的な方法としては、性別テーブルを別に作って外部キー制約をつけてください。
詳しくは、「データーベース 正規化」でWebページを検索して読んで下さい。

投稿2017/06/01 01:50

hihijiji

総合スコア4150

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/06/01 01:54

ありがとうございます試してみます!
退会済みユーザー

退会済みユーザー

2017/06/01 03:27

無事解決できました! 正規化も勉強になりましたありがとうございます!
guest

0

Qiitaにこんな記事ありますが、こういうことですか?
http://qiita.com/hmatsu47/items/ddf0fc74f2dc3bb7556f

投稿2017/06/01 01:46

kanimaru

総合スコア1013

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/06/01 01:59

僕も調べたときにその記事を見たのですが似てるようで若干違う気がしたので、他の回答者の方達が教えてくださった外部キー試してみたいと思います! 回答ありがとうございます!
退会済みユーザー

退会済みユーザー

2017/06/01 03:27

無事解決できました!ありがとうございます!
guest

0

同環境がないので試せてませんがCHECK制約をエミュレートする方法を紹介する記事がありましたので、
こちらを参考にやりたいことができそうか試してみてください。

CHECK制約をエミュレートする新旧の方法とドメイン (MySQL Server Blogより)

他のやり方?

男、女とだけレコードが入った性別マスタテーブルを作って、「性別」カラムに外部キー制約をつけるとそれ以外のデータが入ってこないようにできそうです。

外部キー制約

投稿2017/06/01 01:46

編集2017/06/01 01:50
m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/06/01 01:55

ありがとうございます! 試してみます!
退会済みユーザー

退会済みユーザー

2017/06/01 03:28

無事解決できました!ありがとうございます!
guest

0

ENUM型を使わずに実現したい

の意図がわかりかねます。
やっていることは入力制限をかけてることなので同じです
それ以外となると
SET型をつかうか、外部キー制約をつかうのが妥当です

投稿2017/06/01 01:50

yambejp

総合スコア114769

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/06/01 01:54

ありがとうございます試してみます。
退会済みユーザー

退会済みユーザー

2017/06/01 03:27

無事解決できました!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問