Merge pull request #139 from strongloop/replace

Implementation of ReplaceOrCreate - mysql
This commit is contained in:
Amir-61 2016-03-28 17:12:08 -04:00
commit fe58c75460
2 changed files with 101 additions and 12 deletions

View File

@ -200,17 +200,7 @@ MySQL.prototype.executeSQL = function(sql, params, options, callback) {
} }
}; };
/** MySQL.prototype._modifyOrCreate = function(model, data, options, fields, cb) {
* Update if the model instance exists with the same id or create a new instance
*
* @param {String} model The model name
* @param {Object} data The model instance data
* @param {Function} [callback] The callback function
*/
MySQL.prototype.updateOrCreate = MySQL.prototype.save =
function(model, data, options, callback) {
var fields = this.buildFields(model, data);
var sql = new ParameterizedSQL('INSERT INTO ' + this.tableEscaped(model)); var sql = new ParameterizedSQL('INSERT INTO ' + this.tableEscaped(model));
var columnValues = fields.columnValues; var columnValues = fields.columnValues;
var fieldNames = fields.names; var fieldNames = fields.names;
@ -246,10 +236,37 @@ MySQL.prototype.updateOrCreate = MySQL.prototype.save =
// 2 for each successful UPDATE. // 2 for each successful UPDATE.
meta.isNewInstance = (info.affectedRows === 1); meta.isNewInstance = (info.affectedRows === 1);
} }
callback(err, data, meta); cb(err, data, meta);
}); });
}; };
/**
* Replace if the model instance exists with the same id or create a new instance
*
* @param {String} model The model name
* @param {Object} data The model instance data
* @param {Object} options The options
* @param {Function} [cb] The callback function
*/
MySQL.prototype.replaceOrCreate = function(model, data, options, cb) {
var fields = this.buildReplaceFields(model, data);
this._modifyOrCreate(model, data, options, fields, cb);
};
/**
* Update if the model instance exists with the same id or create a new instance
*
* @param {String} model The model name
* @param {Object} data The model instance data
* @param {Object} options The options
* @param {Function} [cb] The callback function
*/
MySQL.prototype.save =
MySQL.prototype.updateOrCreate = function(model, data, options, cb) {
var fields = this.buildFields(model, data);
this._modifyOrCreate(model, data, options, fields, cb);
};
function dateToMysql(val) { function dateToMysql(val) {
return val.getUTCFullYear() + '-' + return val.getUTCFullYear() + '-' +
fillZeros(val.getUTCMonth() + 1) + '-' + fillZeros(val.getUTCMonth() + 1) + '-' +

View File

@ -156,6 +156,78 @@ describe('mysql', function () {
}); });
context('replaceOrCreate', function() {
it('should replace the instance', function(done) {
Post.create({title: 'a', content: 'AAA'}, function(err, post) {
if (err) return done(err);
post = post.toObject();
delete post.content;
Post.replaceOrCreate(post, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
p.title.should.equal('a');
should.not.exist(p.content);
should.not.exist(p._id);
Post.findById(post.id, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
p.title.should.equal('a');
should.not.exist(post.content);
should.not.exist(p._id);
done();
});
});
});
});
it('should replace with new data', function(done) {
Post.create({title: 'a', content: 'AAA', comments: ['Comment1']},
function(err, post) {
if (err) return done(err);
post = post.toObject();
delete post.comments;
delete post.content;
post.title = 'b';
Post.replaceOrCreate(post, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
should.not.exist(p._id);
p.title.should.equal('b');
should.not.exist(p.content);
should.not.exist(p.comments);
Post.findById(post.id, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
should.not.exist(p._id);
p.title.should.equal('b');
should.not.exist(p.content);
should.not.exist(p.comments);
done();
});
});
});
});
it('should create a new instance if it does not exist', function(done) {
var post = {id: 123, title: 'a', content: 'AAA'};
Post.replaceOrCreate(post, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
should.not.exist(p._id);
p.title.should.equal(post.title);
p.content.should.equal(post.content);
Post.findById(p.id, function(err, p) {
if (err) return done(err);
p.id.should.equal(post.id);
should.not.exist(p._id);
p.title.should.equal(post.title);
p.content.should.equal(post.content);
done();
});
});
});
});
it('save should update the instance with the same id', function (done) { it('save should update the instance with the same id', function (done) {
Post.create({title: 'a', content: 'AAA'}, function (err, post) { Post.create({title: 'a', content: 'AAA'}, function (err, post) {
post.title = 'b'; post.title = 'b';