Map NaN to null
This commit is contained in:
parent
6988e1bdea
commit
cb8f06c4ab
20
lib/mysql.js
20
lib/mysql.js
|
@ -324,6 +324,9 @@ MySQL.prototype.toDatabase = function (prop, val, forCreate) {
|
||||||
return this.client.escape(val);
|
return this.client.escape(val);
|
||||||
}
|
}
|
||||||
if (prop.type === Number) {
|
if (prop.type === Number) {
|
||||||
|
if (isNaN(val)) {
|
||||||
|
return 'NULL';
|
||||||
|
}
|
||||||
return this.client.escape(val);
|
return this.client.escape(val);
|
||||||
}
|
}
|
||||||
if (prop.type === Date) {
|
if (prop.type === Date) {
|
||||||
|
@ -507,9 +510,13 @@ MySQL.prototype._buildWhere = function (model, conds) {
|
||||||
}
|
}
|
||||||
sqlCond += (condType === 'inq' || condType === 'nin') ? '(' + val + ')' : val;
|
sqlCond += (condType === 'inq' || condType === 'nin') ? '(' + val + ')' : val;
|
||||||
cs.push(sqlCond);
|
cs.push(sqlCond);
|
||||||
|
} else {
|
||||||
|
if (val === 'NULL') {
|
||||||
|
cs.push(keyEscaped + ' IS NULL');
|
||||||
} else {
|
} else {
|
||||||
cs.push(keyEscaped + ' = ' + val);
|
cs.push(keyEscaped + ' = ' + val);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
if (cs.length === 0) {
|
if (cs.length === 0) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -595,6 +602,19 @@ MySQL.prototype.all = function all(model, filter, callback) {
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
MySQL.prototype.find = function find(model, id, callback) {
|
||||||
|
var idName = this.idName(model);
|
||||||
|
var filter = {where: {}, limit: 1};
|
||||||
|
filter.where[idName] = id;
|
||||||
|
this.all(model, filter, function(err, results) {
|
||||||
|
if (err) {
|
||||||
|
return callback && callback(err);
|
||||||
|
} else {
|
||||||
|
return callback && callback(results && results[0]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
MySQL.prototype.count = function count(model, callback, where) {
|
MySQL.prototype.count = function count(model, callback, where) {
|
||||||
|
|
||||||
this.query('SELECT count(*) as cnt FROM ' +
|
this.query('SELECT count(*) as cnt FROM ' +
|
||||||
|
|
|
@ -455,6 +455,18 @@ describe('mysql', function () {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should convert NaN to NULL for query', function(done) {
|
||||||
|
Post.create({title: 'My Post1', content: 'Hello', stars: 5},
|
||||||
|
function(err, post) {
|
||||||
|
Post.findById('x',
|
||||||
|
function(err, post) {
|
||||||
|
should.not.exist(err);
|
||||||
|
should.not.exist(post);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
it('should not allow duplicate titles', function (done) {
|
it('should not allow duplicate titles', function (done) {
|
||||||
var data = {title: 'a', content: 'AAA'};
|
var data = {title: 'a', content: 'AAA'};
|
||||||
PostWithUniqueTitle.create(data, function (err, post) {
|
PostWithUniqueTitle.create(data, function (err, post) {
|
||||||
|
|
Loading…
Reference in New Issue