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

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

ただいまの
回答率

90.48%

  • MySQL

    6016questions

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

MySQL WorkbenchでエクスポートしたSQLをphpMyAdminで取り込めない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 198

msx2

score 149

タイトルそのままなのですが、WorkbenchでエクスポートしたSQLをphpMyAdminで取り込むとアップロードがいつまでも終わらずMySQLサーバーも固まってしまいます。

もちろんWorkbenchでは取り込めるのですが、同じMySQLのSQL文なのにどうしてでしょうか?

下記が実行したSQLです。
膨大な量のデータをインポートするでもないのですがアップロードで止まってしまい、その後は別タブでphpMyAdminを開こうとしてもログイン画面すら表示されなくなるのです。

仮想マシンで立てているサーバーなので再起動するまで復旧しません。

-- MySQL dump 10.13  Distrib 5.7.17, for Win64 (x86_64)
--
-- Host: localhost    Database: sgq_db
-- ------------------------------------------------------
-- Server version    5.7.11

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `mall`
--

DROP TABLE IF EXISTS `mall`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `mall` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `mall_no` int(2) NOT NULL,
  `mall_code` varchar(8) NOT NULL,
  `mall_name` varchar(100) NOT NULL,
  `order` int(2) NOT NULL,
  `image_id` int(11) DEFAULT NULL,
  `created_at` int(11) DEFAULT NULL,
  `updated_at` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_mall` (`mall_no`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `mall`
--

LOCK TABLES `mall` WRITE;
/*!40000 ALTER TABLE `mall` DISABLE KEYS */;
INSERT INTO `mall` VALUES (1,1,'RAK','楽天市場',1,NULL,NULL,NULL),(2,2,'YAH','Yahoo!ショッピング',2,NULL,NULL,NULL),(3,3,'AMA','Amazon',3,NULL,NULL,NULL);
/*!40000 ALTER TABLE `mall` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

-- Dump completed on 2018-05-17 17:41:59
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

phpMyAdminはwebアプリケーションであり、webアプリケーションではファイルアップロードサイズと処理時間に上限を定めるのが一般的です。

こんな感じでアップロードサイズの最大値を増やしたり
処理時間の上限を増やしたり

すると大きなサイズのファイルもインポート出来るようになります。(サーバスペック的に負荷が高すぎる状態になるとそれでも失敗します)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/19 09:25

    ご回答ありがとうございます。
    すいません質問の仕方が悪かったです。
    インポートしているデータは数件でSQL自体も短いものです。
    質問に実行したSQLを質問に追加しました。

    キャンセル

  • 2018/05/19 12:13

    サイズや処理時間は関係無さそうですね。

    1. Webサーバとmysqlのログに何かエラーは出ていませんか?
    2. [仮想マシンで立てているサーバーなので再起動するまで復旧しません。] と言うのはapacheの再起動を指しますか?

    キャンセル

  • 2018/05/19 12:50

    MySQLのログは特に異常なさそうです。
    再起動とは仮想マシン自体をシャットダウンして再起動しています。

    キャンセル

  • 2018/05/19 18:41

    切り分けに至るかはわかりませんが。。。
    1. MySQLのみ、apahceのみを再起動した場合はそれぞれどうなりますか?
    2. phpMyAdminで使っているユーザとMySQL workbenchで使っているユーザーは同じですか?
    3. phpMyAdminではデータベースを選んでからのインポートと、全体からのインポートがあったと記憶していますが(最近使ってないので違うかも)具体的にどの画面からどのようにインポートしているか教えてください。
    4. https://tech.basicinc.jp/articles/41 を参考にして、止まっている間のプロセスについて調べるとどうなるか追記してください

    キャンセル

  • 2018/05/20 10:09

    ありがとうございます。
    あれから色々と試してみたのですが、どうやらコメントをなくして完全にSQLの構文だけにしてしまうと動くみたいです。

    コメントで無視されていると思い込んでいた

    /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

    のような行が、調べてみるとMySQLのバージョンによって動いたり動かなかったりする命令になっているみたいです。
    これらのコメント文が具体的に何をしているのかは理解できていませんが、コメントを全て消すことでインポートは無事成功しました。

    どのコメントが実行を妨げているのか明らかにしていきたいと思いますが、それはもう少し自分なりに調べてみてわからなければ別の質問として投稿することにします。

    この度はお付き合いいただきまして本当にありがとうございます。
    一人だったら間違いなく途中で投げていたと思います。
    とても勉強になりました。

    キャンセル

関連した質問

同じタグがついた質問を見る

  • MySQL

    6016questions

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