jet/sqlbuilder/expression_table.go

95 lines
2.6 KiB
Go
Raw Normal View History

package sqlbuilder
2019-05-07 19:06:21 +02:00
type expressionTable interface {
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-05-07 19:06:21 +02:00
statement expression
columns []column
alias string
}
2019-04-07 09:58:12 +02:00
// Returns the tableName's name in the database
func (t *expressionTableImpl) SchemaName() string {
2019-04-07 09:58:12 +02:00
return ""
}
func (s *expressionTableImpl) TableName() string {
2019-04-07 09:58:12 +02:00
return s.alias
}
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) Columns() []column {
return s.columns
}
func (s *expressionTableImpl) RefIntColumnName(name string) *IntegerColumn {
intColumn := NewIntegerColumn(name, NotNullable)
intColumn.setTableName(s.alias)
return intColumn
}
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) RefIntColumn(column column) *IntegerColumn {
intColumn := NewIntegerColumn(column.TableName()+"."+column.Name(), NotNullable)
intColumn.setTableName(s.alias)
return intColumn
}
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) RefStringColumn(column column) *StringColumn {
strColumn := NewStringColumn(column.Name(), NotNullable)
strColumn.setTableName(column.TableName())
return strColumn
}
func (s *expressionTableImpl) serialize(statement statementType, out *queryData) error {
out.writeString("( ")
err := s.statement.serialize(statement, out)
if err != nil {
return err
}
out.writeString(" ) AS ")
out.writeString(s.alias)
return nil
}
// Generates a select query on the current tableName.
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) SELECT(projections ...projection) selectStatement {
return newSelectStatement(s, projections)
}
// Creates a inner join tableName expression using onCondition.
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) INNER_JOIN(table readableTable, onCondition boolExpression) readableTable {
return InnerJoinOn(s, table, onCondition)
}
2019-05-07 19:06:21 +02:00
//func (s *expressionTableImpl) InnerJoinUsing(table readableTable, col1 column, col2 column) readableTable {
// return INNER_JOIN(s, table, col1.Eq(col2))
2019-03-31 14:07:58 +02:00
//}
// Creates a left join tableName expression using onCondition.
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) LEFT_JOIN(table readableTable, onCondition boolExpression) readableTable {
return LeftJoinOn(s, table, onCondition)
}
// Creates a right join tableName expression using onCondition.
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) RIGHT_JOIN(table readableTable, onCondition boolExpression) readableTable {
return RightJoinOn(s, table, onCondition)
}
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) FULL_JOIN(table readableTable, onCondition boolExpression) readableTable {
2019-03-31 14:07:58 +02:00
return FullJoin(s, table, onCondition)
}
2019-05-07 19:06:21 +02:00
func (s *expressionTableImpl) CROSS_JOIN(table readableTable) readableTable {
return CrossJoin(s, table)
}