Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/443.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/34.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript sequelize.js在插入到数据库进程后不会';t退出/关闭_Javascript_Node.js_Sequelize.js - Fatal编程技术网

Javascript sequelize.js在插入到数据库进程后不会';t退出/关闭

Javascript sequelize.js在插入到数据库进程后不会';t退出/关闭,javascript,node.js,sequelize.js,Javascript,Node.js,Sequelize.js,我的模型 index.js 'use strict'; var fs = require('fs'); var path = require('path'); var Sequelize = require('sequelize'); var basename = path.basename(module.filename); var env = process.env.NODE_ENV || 'development'; var config =

我的模型

index.js

'use strict';

var fs        = require('fs');
var path      = require('path');
var Sequelize = require('sequelize');
var basename  = path.basename(module.filename);
var env       = process.env.NODE_ENV || 'development';
var config    = require(__dirname + '/../config/config.json')[env];
var db        = {};

if (config.use_env_variable) {
  var sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
  var sequelize = new Sequelize(config.database, config.username, config.password, config);
}

fs
  .readdirSync(__dirname)
  .filter(function(file) {
    return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
  })
  .forEach(function(file) {
    var model = sequelize['import'](path.join(__dirname, file));
    db[model.name] = model;
  });

Object.keys(db).forEach(function(modelName) {
  if (db[modelName].associate) {
    db[modelName].associate(db);
  }
});

db.sequelize = sequelize;

module.exports = db;
'use strict';
module.exports = function(sequelize, DataTypes) {
  var Course = sequelize.define('Course', {
    title: DataTypes.STRING,
    url: DataTypes.STRING,
    downloaded: DataTypes.BOOLEAN,
    date_published: DataTypes.DATEONLY
  }, {
    underscored: true,
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  });
  return Course;
};
const Course = require('./models').Course
const courses = [
    {
        title: 'xyz1',
        url: 'https://www.example.com/xyz1'
    },
    {
        title: 'xyz2',
        url: 'https://www.example.com/xyz2'
    }
]


courses.forEach(item => Course.create(item).then(course => {}))
course.js

'use strict';

var fs        = require('fs');
var path      = require('path');
var Sequelize = require('sequelize');
var basename  = path.basename(module.filename);
var env       = process.env.NODE_ENV || 'development';
var config    = require(__dirname + '/../config/config.json')[env];
var db        = {};

if (config.use_env_variable) {
  var sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
  var sequelize = new Sequelize(config.database, config.username, config.password, config);
}

fs
  .readdirSync(__dirname)
  .filter(function(file) {
    return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
  })
  .forEach(function(file) {
    var model = sequelize['import'](path.join(__dirname, file));
    db[model.name] = model;
  });

Object.keys(db).forEach(function(modelName) {
  if (db[modelName].associate) {
    db[modelName].associate(db);
  }
});

db.sequelize = sequelize;

module.exports = db;
'use strict';
module.exports = function(sequelize, DataTypes) {
  var Course = sequelize.define('Course', {
    title: DataTypes.STRING,
    url: DataTypes.STRING,
    downloaded: DataTypes.BOOLEAN,
    date_published: DataTypes.DATEONLY
  }, {
    underscored: true,
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  });
  return Course;
};
const Course = require('./models').Course
const courses = [
    {
        title: 'xyz1',
        url: 'https://www.example.com/xyz1'
    },
    {
        title: 'xyz2',
        url: 'https://www.example.com/xyz2'
    }
]


courses.forEach(item => Course.create(item).then(course => {}))
test.js

'use strict';

var fs        = require('fs');
var path      = require('path');
var Sequelize = require('sequelize');
var basename  = path.basename(module.filename);
var env       = process.env.NODE_ENV || 'development';
var config    = require(__dirname + '/../config/config.json')[env];
var db        = {};

if (config.use_env_variable) {
  var sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
  var sequelize = new Sequelize(config.database, config.username, config.password, config);
}

fs
  .readdirSync(__dirname)
  .filter(function(file) {
    return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
  })
  .forEach(function(file) {
    var model = sequelize['import'](path.join(__dirname, file));
    db[model.name] = model;
  });

Object.keys(db).forEach(function(modelName) {
  if (db[modelName].associate) {
    db[modelName].associate(db);
  }
});

db.sequelize = sequelize;

module.exports = db;
'use strict';
module.exports = function(sequelize, DataTypes) {
  var Course = sequelize.define('Course', {
    title: DataTypes.STRING,
    url: DataTypes.STRING,
    downloaded: DataTypes.BOOLEAN,
    date_published: DataTypes.DATEONLY
  }, {
    underscored: true,
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  });
  return Course;
};
const Course = require('./models').Course
const courses = [
    {
        title: 'xyz1',
        url: 'https://www.example.com/xyz1'
    },
    {
        title: 'xyz2',
        url: 'https://www.example.com/xyz2'
    }
]


courses.forEach(item => Course.create(item).then(course => {}))
我的问题:
现在运行
节点test.js
时,它不会在编码后退出 执行


尝试将代码改写为-

const db = require('./models');
const Course = db.Course;

const courses = [
    {
        title: 'xyz1',
        url: 'https://www.example.com/xyz1'
    },
    {
        title: 'xyz2',
        url: 'https://www.example.com/xyz2'
    }
];

function _createCourses(courseList) {
   courseList.forEach(course => {
      Course.create(course).then(createdCourse => {
         console.log(createdCourse.get({
            plain: true
         }));
      });
   });
}

db.sequelize.sync()
  .then(() => {
     _createCourses(courses);
  });

这里唯一的区别是我们在创建模型对象之前调用
sequalize.sync
<代码>同步实际上同步数据库中所有定义的模型。查看文档了解详细信息-

当我们从命令行运行脚本时,sequelize连接池未关闭,这就是为什么我们需要调用sequelize.close()()在完成的作业上关闭池,或者运行
process.exit()
,这也会杀死池


在节点中,直到完成所有工作,例如,事件侦听某物或任何
setInterval
或类似于此处,任何打开的连接(套接字连接)执行都不会完成。这就是为什么死刑没有在这里结束。

@Praveen这个案子实际上不是我的