knex/lib/builder/joinclause.js

50 lines
1.3 KiB
JavaScript
Raw Normal View History

2013-09-13 16:58:38 -04:00
// JoinClause
// ---------
(function(define) {
"use strict";
define(function(require, exports) {
2013-09-17 07:15:18 -04:00
// The "JoinClause" is an object holding any necessary info about a join,
// including the type, and any associated tables & columns being joined.
var JoinClause = function(type, table) {
this.joinType = type;
this.table = table;
this.clauses = [];
};
JoinClause.prototype = {
2013-09-17 07:15:18 -04:00
// Adds an "on" clause to the current join object.
on: function(first, operator, second) {
this.clauses.push({first: first, operator: operator, second: second, bool: 'and'});
return this;
},
2013-09-17 07:15:18 -04:00
// Adds an "and on" clause to the current join object.
andOn: function() {
return this.on.apply(this, arguments);
},
2013-09-17 07:15:18 -04:00
// Adds an "or on" clause to the current join object.
orOn: function(first, operator, second) {
this.clauses.push({first: first, operator: operator, second: second, bool: 'or'});
return this;
},
2013-09-17 07:15:18 -04:00
// Explicitly set the type of join, useful within a function when creating a grouped join.
type: function(type) {
this.joinType = type;
return this;
}
};
exports.JoinClause = JoinClause;
});
})(
typeof define === 'function' && define.amd ? define : function (factory) { factory(require, exports); }
);