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

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

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

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

Q&A

解決済

1回答

2381閲覧

XAMPP phpMyAdmin4.5.3.1 MariaDBでSQL文に「CHARSET=utf8」が発行されエラー

rik

総合スコア1151

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

XAMPP

XAMPP(ザンプ)は、ウェブアプリケーションの実行に必要なフリーソフトウェアをパッケージングしたApacheディストリビューションです。 XAMPPひとつインストールするだけで、Apache、MySQL、PHP、Perlなどのソフトウェアと、 phpMyAdminなどの管理ツール、SQLiteなどのソフトウェアやライブラリモジュールなどを利用することが可能です。

0グッド

0クリップ

投稿2016/01/05 14:41

編集2016/01/05 15:40

最近XAMPPをv3.2.2(compiled:Nov 12th 2015)でphp7に変更しました。
phpMyAdmin4.5.3.1(この時点で最新)でALTER TABLEを発行するとシンタックスエラーが出たため、調べたところ自動発行されるSQL文の「CHARSET=utf8」を削除すると正常動作することが分かりました。

以下、phpMyAdminのトップページの表示

データベースサーバ
サーバ: 127.0.0.1 via TCP/IP
サーバの種類: MariaDB
サーバのバージョン: 10.1.9-MariaDB - mariadb.org binary distribution
プロトコル バージョン: 10
ユーザ: root@localhost
サーバの文字セット: UTF-8 Unicode (utf8)

ウェブサーバ
Apache/2.4.18 (Win32) OpenSSL/1.0.2e PHP/7.0.0
データベースクライアントのバージョン: libmysql - mysqlnd 5.0.12-dev - 20150407 - $Id: xxx $
PHP 拡張: mysqli ドキュメント
PHP version: 7.0.0

MariaDBでは「CHARSET=xxx」という文法が存在しないという事が予測できるのですが、それ以外の理由によるものなのか、またはphpMyAdminで「CHARSET=xxx」を発行させない方法を知りたいです。

sql

1失敗例(自動発行されるSQL)2ALTER TABLE `category` CHANGE `pathname` `pathname` VARCHAR(128) CHARSET=utf8 COLLATE utf8_bin NULL DEFAULT NULL 3 4成功例(CHARSETを削除)5ALTER TABLE `category` CHANGE `pathname` `pathname` VARCHAR(128) COLLATE utf8_bin NULL DEFAULT NULL

(とりあえず自動発行されるSQL文を修正して実行しています。)
よろしくお願い致します。

追記:
フィールドを増やす場合のALTER TABLEではCHARSETが発行されず、既存フィールドを変更する場合はこの問題が生じますので、単なる不具合でしょうか??

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

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

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

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

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

guest

回答1

0

ベストアンサー

ALTER TABLE で CHARSET=utf8 という構文はMySQLでもエラーになります。
本来は CHARACTER SET utf8 とすべきところです。
これはphpMyAdmin4.5.3系のバグのようで、4.5.4で修正されたように見えます。
https://www.phpmyadmin.net/files/4.5.4/

投稿2016/02/09 00:23

dupont_kedama

総合スコア925

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

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

rik

2016/02/09 00:30

「#11777 While 'changing a column', query fails with a syntax error after the 'CHARSET=' keyword」 これですね。ありがとうございます。試してみます。 情報ありがとうございました。
rik

2016/02/09 00:38

phpMyAdminをアップデートしました。 CHARSET=utf8 は発行されず、代わりに CHARACTER SET utf8 が発行されました。 やはりバグだったようですね。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問