jet/sqlbuilder/expression_table.go

99 lines
2.7 KiB
Go
Raw Normal View History

package sqlbuilder
2019-05-13 12:33:11 +02:00
import "errors"
2019-05-07 19:06:21 +02:00
type expressionTable interface {
2019-06-04 12:10:23 +02:00
ReadableTable
RefIntColumnName(name string) *IntegerColumn
2019-05-07 19:06:21 +02:00
RefIntColumn(column column) *IntegerColumn
RefStringColumn(column column) *StringColumn
}
type expressionTableImpl struct {
2019-06-04 12:10:23 +02:00
statement Expression
alias string
}
2019-04-07 09:58:12 +02:00
// Returns the tableName's name in the database
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) SchemaName() string {
2019-04-07 09:58:12 +02:00
return ""
}
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) TableName() string {
return e.alias
2019-04-07 09:58:12 +02:00
}
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) Columns() []column {
2019-05-12 18:15:23 +02:00
return []column{}
}
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) RefIntColumnName(name string) *IntegerColumn {
intColumn := NewIntegerColumn(name, NotNullable)
2019-05-13 12:33:11 +02:00
intColumn.setTableName(e.alias)
return intColumn
}
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) RefIntColumn(column column) *IntegerColumn {
intColumn := NewIntegerColumn(column.TableName()+"."+column.Name(), NotNullable)
2019-05-13 12:33:11 +02:00
intColumn.setTableName(e.alias)
return intColumn
}
2019-05-13 12:33:11 +02:00
func (e *expressionTableImpl) RefStringColumn(column column) *StringColumn {
2019-05-12 18:15:23 +02:00
strColumn := NewStringColumn(column.TableName()+"."+column.Name(), NotNullable)
2019-05-13 12:33:11 +02:00
strColumn.setTableName(e.alias)
return strColumn
}
func (e *expressionTableImpl) serialize(statement statementType, out *queryData, options ...serializeOption) error {
2019-05-13 12:33:11 +02:00
if e == nil {
return errors.New("Expression table is nil. ")
}
2019-05-12 18:15:23 +02:00
//out.writeString("( ")
2019-05-13 12:33:11 +02:00
err := e.statement.serialize(statement, out)
if err != nil {
return err
}
2019-05-12 18:15:23 +02:00
out.writeString("AS")
2019-05-13 12:33:11 +02:00
out.writeString(e.alias)
return nil
}
// Generates a select query on the current tableName.
2019-06-04 12:10:23 +02:00
func (e *expressionTableImpl) SELECT(projections ...projection) SelectStatement {
2019-05-13 12:33:11 +02:00
return newSelectStatement(e, projections)
}
2019-06-04 12:10:23 +02:00
// Creates a inner join tableName Expression using onCondition.
func (e *expressionTableImpl) INNER_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
2019-05-13 12:33:11 +02:00
return InnerJoinOn(e, table, onCondition)
}
2019-06-04 12:10:23 +02:00
//func (s *expressionTableImpl) InnerJoinUsing(table ReadableTable, col1 column, col2 column) ReadableTable {
2019-05-29 14:03:38 +02:00
// return INNER_JOIN(s, table, col1.EQ(col2))
2019-03-31 14:07:58 +02:00
//}
2019-06-04 12:10:23 +02:00
// Creates a left join tableName Expression using onCondition.
func (e *expressionTableImpl) LEFT_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
2019-05-13 12:33:11 +02:00
return LeftJoinOn(e, table, onCondition)
}
2019-06-04 12:10:23 +02:00
// Creates a right join tableName Expression using onCondition.
func (e *expressionTableImpl) RIGHT_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
2019-05-13 12:33:11 +02:00
return RightJoinOn(e, table, onCondition)
}
2019-06-04 12:10:23 +02:00
func (e *expressionTableImpl) FULL_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
2019-05-13 12:33:11 +02:00
return FullJoin(e, table, onCondition)
}
2019-06-04 12:10:23 +02:00
func (e *expressionTableImpl) CROSS_JOIN(table ReadableTable) ReadableTable {
2019-05-13 12:33:11 +02:00
return CrossJoin(e, table)
}