带有ORM2和分离模型文件的Node Express。



我正在使用node&express(node框架)。我不想使用 node-orm2 框架来与我的 MySQL 数据库进行通信。为了保持良好的结构,我想将我的模型拆分为单独的文件。我一直在使用 github 上的文档,但不知何故我无法让它工作。

应用.js:

app.use(orm.express("mysql://********:********@localhost/*********",
{
    define: function(db, models){
        db.load('./models', function(err){
            models.movie = db.models.Movie;
        });
    }
}));

型号.js:

module.exports = function (db, fn) {
    db.load("movie", function (err) {
        if (err) {
            return fn(err);
        }
    });
//etc
return fn();
};

电影.js:

module.exports = function (db, fn) {
    db.define('movie', {
        id          : { type: "number" },
        title       : { type: "text" },
        year        : { type: "number" },
        rating      : { type: "number" },
        description : { type: "text" }
    }, {
        methods : {
        }
    });
    return fn();
};

从 github 问题跟踪器复制的帮助(来自 lastmove):

我正在使用内置的快速中间件。它对我来说效果很好。我有一个文件夹模型。使用一个文件标准模型。用户模型示例:用户.js

module.exports = function(db, cb)
{
    var User = db.define('user', {
              userName : String,
              password : String,
              mail : String,
              mark : Number,
              lastAlertSent : Date,
              subscriptionDate : Date,
              lastAction : Date,
              specialUser : Boolean,
              uuid  : String
              },
              {
         validations:
                 {
                  userName : [orm.enforce.required(error.errorStr(error.missingRequiredField, "userName missing")), orm.enforce.unique({ ignoreCase: true },  error.errorStr(error.usernameAlreadyUsed, "userName already used")), orm.enforce.ranges.length(3, undefined, error.errorStr(error.usernameTooShort, "userName too shoty"))], 
...

在"模型"文件夹中,我有一个索引.js在此文件中,我定义了模型之间的关系,并加载了模型。

文件:型号/索引.js

checkError = function(cb, err)
{
    if (err)
        return cb(err);
    return cb();
}
module.exports = function(db, cb)
{
    db.load("./user.js", function (err) {checkError(cb, err)});
    db.load("./alert.js", function (err) {checkError(cb, err)});
    db.load("./comment.js", function (err) {checkError(cb, err)});
    db.load("./metropole.js", function (err) {checkError(cb, err)});
    db.load("./period.js", function (err) {checkError(cb, err)});
    db.load("./stop.js", function (err) {checkError(cb, err)});
    db.load("./line.js", function (err) {checkError(cb, err)});
    db.load("./types.js", function (err) {checkError(cb, err)});
    db.load("./historique.js", function(err) {checkError(cb, err)});
    var User = db.models.user;
    var Alert = db.models.alert;
    var Comment = db.models.comment;
    var Metropole = db.models.metropole;
    var Stop = db.models.stop;
    var Line = db.models.line;
    var Period = db.models.period;
    var Types = db.models.types;
    var Hist = db.models.historique;
    Alert.hasOne("stop", Stop, {reverse : "alerts"});
    Alert.hasOne("line", Line, {reverse : "alerts"});

毕竟在我的快速初始化中,我添加了以下内容:

app.use(orm.express(opts, {
    define: function (db, models, next) {
            db.load("./models/models", function (err2)
        {
            if (err2)   
                throw err2;
            db.sync();
        })
        next();
    }

最新更新