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

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

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

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

Q&A

解決済

4回答

1643閲覧

mysql varchar の容量

y.ssss

総合スコア27

MySQL

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

0グッド

0クリップ

投稿2020/05/18 00:09

Create table texts( -> request_text varchar(10000), -> answered_text varchar(10000) -> );

上記のような質問と答えをもつデータベースがあったとして、

ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

createすると上記のようなエラーになります。
ようはtext使え的なことだと思うのですが、varcahrの容量は20000で限界にきてしまうのですか?
65,535がmaxだと思っていたので、イマイチ理解できていないようです。

初歩的なことで申し訳ないのですが、ご教授願います。。

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

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

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

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

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

maisumakun

2020/05/18 02:09

そもそも論ですが、textでなくvarcharである必要はありますか?
y.ssss

2020/05/18 20:18

いわば遊びのような感覚でDBをいじっていましたら、今回のような事象に出くわしました。 それで興味が湧いて質問させていただいた次第です。。。 実際に用いる際はそうさせていただきます! ご教授ありがとうございます。
guest

回答4

0

そもそもvarcharを万能だとおもわないこと
長めのデータが想定されるならtext(or MEDIUMTEXT/LONGTEXT)を検討ください

投稿2020/05/18 02:06

yambejp

総合スコア116724

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

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

0

ベストアンサー

たぶん質問者さんの MySQL の文字コードが utf8mb4 なので、バイト数が、

(10000 + 10000) x 4 = 80000 > 65535 バイト

となって制限を超えたのではないでしょうか。

文字コードは show variables like "chara%"; で調べられます。

イメージ説明

投稿2020/05/18 00:43

編集2020/05/18 02:07
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

y.ssss

2020/05/18 20:15

なるほどです! 勉強になりました! ありがとうございます
guest

0

投稿2020/05/18 00:17

Orlofsky

総合スコア16417

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

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

0

varcahrの容量は20000で限界にきてしまうのですか?

varcharのサイズは文字数で指定しますが、行のサイズはバイト単位で制限がかかっています。

1文字1バイトのLatin-1などを使う場合を別とすれば、列のバイト数は文字数と一致しません。

投稿2020/05/18 00:12

maisumakun

総合スコア146018

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問