

MySQLのカラム名に日本語を使うか、英数字を使うかで迷っています。英数が無難だと思うのですが、日本語の方が簡潔で分かりやすい命名ができるので、もし大した問題が無ければ日本語を使おうと考えています。
そこで3点お伺いしたく存じます。
1. 日本の企業はMySQLのカラム名に日本語を使っているケースが多いのか、それとも英数字のみのケースが多いのか、最近の傾向をご教示頂けますか。統計は無いと思いますので、体感や自社ルールの場合等でも結構です。
2. 日本語を使うことでセキュリティホールができることは考えられますか。例えば、マルチバイト文字はSQLインジェクション対策をすり抜ける・・・等。
3. 自分なら日本語と英数字のどちらを使うか。理由も添えて頂けると幸いです。
当方の開発環境は、PHP(ver. 5.5.9) + MySQL(ver. 5.6.16)です。
お手数おかけしますが、ご教示お願い致します。
No.1ベストアンサー
- 回答日時:
(1)日本語を使うケースはほぼ100%ないですね
(2)セキュリティはあまり関係ないでしょう
カラム名を検索者がダイレクトに指定することはまずありえないので
カラム名の日本語でインジェクションが発生する可能性はほぼありません。
逆に万が一もしそういう仕組みを考えているならすぐ見直すべきです。
(3)上で否定しておいてなんですが・・・
自分でやる環境はほぼ日本語カラム名をつかっています。
他人を気遣う必要がなく迷惑をかけないなら日本語で十分です。
余談
日本語ではまるケースはいろいろ想定されます。
とくにMySQLのバージョンアップ、枯れたシステムの3.23系から5.0以上に
環境をシフトする際にかなりトラブリました。
システム周りの環境はは数年単位でかわっていくものです。
別環境に移行する準備を当初から想定しておかないと、かなり痛い目を見ます。
また、メンテナンスする際も、かならずしも日本語入力できる環境とは
限らないことから、日本語を利用することによるリスクは高めに想定しておく
必要があります。なんらかの日本語が入力できない状況で、データベースから
エクスポートをしようとしてはまるとか、ないことはないと思います。
バグやエラーなど一般的なトラブルの際にも、日本語に起因する問題なのか
そうでないのか、無駄にチェックが増えるので、デバグも不利になります。
全部ひっくるめて、自分でなんとかする覚悟と技量があるなら、日本語カラム名で
やるメリットはあるので、トライする価値はあるでしょう
お話を伺う限りでは、日本語の使用はメンテナンスが一番の問題のようですね。
デバグの手間を考えると、やはり日本語は面倒です。
ですので、今回は英数字にします。
大変参考になりました。
ご回答頂き、ありがとうございました。
No.2
- 回答日時:
1.ほとんど英数字です。
説明を付けたい場合はcommentで各カラムに説明を日本語で書きます。長くSEをやっていますが、日本語のカラム名は過去に一度見ただけですね。
2.全く関係ありません。
適切にプログラムを書いていればセキュリティー上の問題は発生しません。
逆に英数字だけであってもプログラムに問題があればセキュリティー上の問題が発生します。
3.英数字を使ってます。
そもそもプログラムを書いているときは、基本的に全て半角文字で入力しますから一々日本語変換をするのは効率が悪すぎます。
回答を拝見して、日本語のメリットはあまり無い気がしてきました。
確かにcommentで十分ですね。
今回はDBのカラムには英数字で、設計で用意する表に日本語と英数字で書いておくことにします。
大変参考になりました。
ご回答頂きありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
- 留学・ワーキングホリデー リスニング力、はつきますか?6カ月語学学校行き数年間お金を稼いでまた、6カ月間語学留学に行くのは? 1 2023/02/11 15:49
- 高校 高校入試(英語)についてです 3 2022/10/04 22:45
- 英語 英語のビジネスライティング添削 1 2022/07/21 23:55
- TOEFL・TOEIC・英語検定 英会話の習得 4 2022/06/05 10:23
- マウス・キーボード 教えて! AppleのMagic Keyboard(JIS)をWindows 10で使用次第のですが 2 2022/06/01 18:07
- 英語 突然ですが、日本人が英語を話せない大きな理由は英単語量が少ないことだと思っています。中学校から始める 6 2022/05/05 22:35
- 英語 なんで道を尋ねる外国人(中国人と韓国人など)は「英語」で話してくるのでしょうか? 別に英語圏ではない 5 2023/03/02 00:39
- その他(病気・怪我・症状) 学習障害について 1 2023/05/11 21:36
- 大学受験 高校3年の女です。早稲田大学社会科学部を第1志望にしています。勉強のアドバイスと、現時点で過去問何割 2 2022/08/04 00:01
このQ&Aを見た人はこんなQ&Aも見ています
-
日本語のテーブル名、カラム名の定義について
SQL Server
-
日本語のエイリアスは "で囲う必要があるのでしょうか"
MySQL
-
テーブルに主キーを作らないデメリットは?
その他(Microsoft Office)
-
-
4
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
5
「マスタ」と「テーブル」の違いとはなんでしょうか?
Oracle
-
6
日本語の表名、列名の利用について
Oracle
-
7
データベース関係で、データの洗い替えとはどのような事を行うことでしょう
IT・エンジニアリング
-
8
外部キーだけのテーブル(主キーがない?)
その他(データベース)
-
9
Accessを開くと「排他モードじゃないので変更しても保存できない」との旨の表示が出てしまう。
Access(アクセス)
-
10
一つ前に戻るには…
MySQL
-
11
UTF8のテーブルをODBCドライバ経由のMS Accessから開くと日本語が文字化けする
MySQL
-
12
exeファイルの中身を見ることは可能ですか?
フリーソフト
-
13
SQLで部分的にGROUP BYしたいとき
Oracle
-
14
データの更新方法について
IT・エンジニアリング
-
15
visual studio でインデントを自動的に揃えるショートカットキー
その他(プログラミング・Web制作)
-
16
テーブルやカラムの物理名のネーミングについて
Oracle
-
17
大量のデータを読み込んで表示する速度を改善したい
C言語・C++・C#
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
下記の問合せを行うクエリを、P...
-
mysqlがインストールされている...
-
下記の問合せを行うクエリを、P...
-
下記の問合せを行うクエリを、P...
-
テーブル名が可変の場合のクエ...
-
MySQL NULLだけをカウントして...
-
SQLで漢字名称を都道府県や市区...
-
エラー 1068 (42000): 複数の主...
-
何にかが違うから エラーなんで...
-
MySQLでcreateが使えない MySQL...
-
データベースの接続について
-
同一日に複数レコードがある場...
-
MAMP 99ドル約1.6万円 高い...
-
あってますか?SQL
-
WHERE `年月日` = '晴' OR `年...
-
SQLです教えてくださいお願いし...
-
SQLを作ったのですがうまくいき...
-
(初心者)MySQLやmaraDBで、crea...
-
SQLです教えてくださいお願いし...
-
SQLです教えてくださいお願いし...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
mysqlがインストールされている...
-
同一日に複数レコードがある場...
-
#1062 - '0' は索引 'PRIMARY' ...
-
エラー 1068 (42000): 複数の主...
-
SQLでカラムを追加し、条件に合...
-
テーブル名が可変の場合のクエ...
-
【初歩】ラジオボタンをつかっ...
-
MySQLのテーブル作成でハイフン...
-
mysqlのupdate構文についての質...
-
LIMIT で条件を満たしているの...
-
データベースの接続に失敗して...
-
MySQL NULLだけをカウントして...
-
select *, `人口(男)`AND`人口(...
-
複数DBテーブルからのデータ取得
-
テーブル:生徒名簿 生徒名簿の...
-
htmlコードで書かれた表にphpで...
-
データベースの複製の仕方(mysql)
-
「重複を間引いた数」をcountし...
-
MAMP 99ドル約1.6万円 高い...
-
SQLです教えてくださいお願いし...
おすすめ情報