1

我正在使用节点和快递(节点框架)。我不想使用 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();
};
4

1 回答 1

-1

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

我正在使用内置的快速中间件。这对我来说可以。我有一个文件夹模型。具有一个文件标准模型。用户模型示例:user.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"))], 
...

在 Models 文件夹中,我有一个 index.js 在这个文件中,我定义了我的模型之间的关系,并加载了我的模型。

文件:模型/index.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"});

毕竟在我的 Express 初始化中,我添加了这个:

app.use(orm.express(opts, {
    define: function (db, models, next) {
            db.load("./models/models", function (err2)
        {
            if (err2)   
                throw err2;
            db.sync();
        })
        next();
    }
于 2015-04-21T14:33:58.093 回答