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

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

ただいまの
回答率

90.34%

mysqlにSequelizeを使って、接続

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,409

yusuke_00

score 18

前提・実現したいこと

mysqlにデータを入れ、Express、Sequelizeを使って、接続し、localhost:3000で接続したい

発生している問題・エラーメッセージ

mysqlにデータを入れ、権限をユーザに与えたのですが、うまく、接続出来ません。表示はjadeです。
エラーメッセージ

/Users/yusuke/develop/oono/node_modules/sequelize/lib/dialects/mysql/connection-manager.js:24
      throw new Error('Please install mysql package manually');
      ^

Error: Please install mysql package manually
    at new ConnectionManager (/Users/yusuke/develop/oono/node_modules/sequelize/lib/dialects/mysql/connection-manager.js:24:13)
    at new MysqlDialect (/Users/yusuke/develop/oono/node_modules/sequelize/lib/dialects/mysql/index.js:12:28)
    at new Sequelize (/Users/yusuke/develop/oono/node_modules/sequelize/lib/sequelize.js:233:18)
    at Object.<anonymous> (/Users/yusuke/develop/oono/app.js:15:17)
    at Module._compile (module.js:409:26)
    at Object.Module._extensions..js (module.js:416:10)
    at Module.load (module.js:343:32)
    at Function.Module._load (module.js:300:12)
    at Module.require (module.js:353:17)
    at require (internal/module.js:12:17)
    at Object.<anonymous> (/Users/yusuke/develop/oono/bin/www:7:11)
    at Module._compile (module.js:409:26)
    at Object.Module._extensions..js (module.js:416:10)
    at Module.load (module.js:343:32)
    at Function.Module._load (module.js:300:12)
    at Function.Module.runMain (module.js:441:10)

該当のソースコードapp.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var routes = require('./routes/index');
var users = require('./routes/users');
var app = express();


var Sequelize = require('sequelize');
var sequelize = new Sequelize('test', 'test', 'TEST');

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/users', users);
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


module.exports = app;

routes/index.js

var express = require('express');
var router = express.Router();
var models = require('../models/test.js');
var Test = models.testname;

router.get('/', function(req, res, next) {
  res.render('index',
  { title: 'Express',
    test:Test
 });
});

module.exports = router;

models/test.js

module.exports = function(sequelize,DataTypes){
  var testname = sequelize.define('test_table',{
    Id:{
      field:'id',
      type:DataTypes.INTEGER,
      allowNull:true,
    },
    Name:{
      field:'name',
      type:DataTypes.STRING,
      allowNull:true,
    },
    SecondName:{
      field:'second_name',
      type:DataTypes.STRING,
      allowNull:false,
    },
    createdAt:{
      field:'created_at',
      type:DataTypes.STRING,
      allowNull:true,
    },
    updatedAt:{
      field:'updatedAt',
      type:DataTypes.STRING,
      allowNull:true,
    }
  },{
    tableName:'test_table',
    timestamps:true
  });
  return testname;
}

試したこと

ユーザ権限、スペルミス等、

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

+1

mysqlが、インストールされていませんでした。
凡ミスです。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 90.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

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