2017-11-13 16:36:30 +00:00
|
|
|
|
|
|
|
var Target = require ('./target');
|
|
|
|
var Expr = require ('./expr');
|
|
|
|
var SqlObject = require ('./object');
|
|
|
|
var Type = require ('./join').Type;
|
2017-11-16 14:53:20 +00:00
|
|
|
|
|
|
|
var TypeSql = [
|
|
|
|
'INNER',
|
|
|
|
'LEFT',
|
|
|
|
'RIGHT'
|
|
|
|
];
|
2017-11-13 16:36:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The equivalent of a SQL join.
|
|
|
|
*/
|
|
|
|
module.exports = new Class
|
|
|
|
({
|
|
|
|
Extends: SqlObject
|
|
|
|
,Tag: 'sql-join-table'
|
|
|
|
,Properties:
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The join type.
|
|
|
|
*/
|
|
|
|
type:
|
|
|
|
{
|
|
|
|
enumType: Type
|
|
|
|
,value: 0
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* The right target.
|
|
|
|
*/
|
|
|
|
target:
|
|
|
|
{
|
|
|
|
type: Target
|
|
|
|
,value: null
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* The join on condition.
|
|
|
|
*/
|
|
|
|
condition:
|
|
|
|
{
|
|
|
|
type: Expr
|
|
|
|
,value: null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
,render: function (params)
|
|
|
|
{
|
|
|
|
return TypeSql[this.type] +' JOIN '
|
|
|
|
+ this.target.render (params)
|
|
|
|
+ this.renderIfSet (this.condition, 'ON', params);
|
|
|
|
}
|
|
|
|
});
|