Table interface cleanup.
This commit is contained in:
parent
8f51662fe5
commit
4d7fbf8f49
32 changed files with 543 additions and 794 deletions
|
|
@ -6,13 +6,22 @@ type expressionTable interface {
|
|||
ReadableTable
|
||||
|
||||
RefIntColumnName(name string) *IntegerColumn
|
||||
RefIntColumn(column column) *IntegerColumn
|
||||
RefStringColumn(column column) *StringColumn
|
||||
RefIntColumn(column Column) *IntegerColumn
|
||||
RefStringColumn(column Column) *StringColumn
|
||||
}
|
||||
|
||||
type expressionTableImpl struct {
|
||||
statement Expression
|
||||
alias string
|
||||
readableTableInterfaceImpl
|
||||
expression Expression
|
||||
alias string
|
||||
}
|
||||
|
||||
func newExpressionTable(expression Expression, alias string) expressionTable {
|
||||
expTable := &expressionTableImpl{expression: expression, alias: alias}
|
||||
|
||||
expTable.readableTableInterfaceImpl.parent = expTable
|
||||
|
||||
return expTable
|
||||
}
|
||||
|
||||
// Returns the tableName's name in the database
|
||||
|
|
@ -24,26 +33,22 @@ func (e *expressionTableImpl) TableName() string {
|
|||
return e.alias
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) Columns() []column {
|
||||
return []column{}
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) RefIntColumnName(name string) *IntegerColumn {
|
||||
intColumn := NewIntegerColumn(name, NotNullable)
|
||||
intColumn := NewIntegerColumn(name, false)
|
||||
intColumn.setTableName(e.alias)
|
||||
|
||||
return intColumn
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) RefIntColumn(column column) *IntegerColumn {
|
||||
intColumn := NewIntegerColumn(column.TableName()+"."+column.Name(), NotNullable)
|
||||
func (e *expressionTableImpl) RefIntColumn(column Column) *IntegerColumn {
|
||||
intColumn := NewIntegerColumn(column.TableName()+"."+column.Name(), false)
|
||||
intColumn.setTableName(e.alias)
|
||||
|
||||
return intColumn
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) RefStringColumn(column column) *StringColumn {
|
||||
strColumn := NewStringColumn(column.TableName()+"."+column.Name(), NotNullable)
|
||||
func (e *expressionTableImpl) RefStringColumn(column Column) *StringColumn {
|
||||
strColumn := NewStringColumn(column.TableName()+"."+column.Name(), false)
|
||||
strColumn.setTableName(e.alias)
|
||||
return strColumn
|
||||
}
|
||||
|
|
@ -53,7 +58,7 @@ func (e *expressionTableImpl) serialize(statement statementType, out *queryData,
|
|||
return errors.New("Expression table is nil. ")
|
||||
}
|
||||
//out.writeString("( ")
|
||||
err := e.statement.serialize(statement, out)
|
||||
err := e.expression.serialize(statement, out)
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
|
|
@ -64,35 +69,3 @@ func (e *expressionTableImpl) serialize(statement statementType, out *queryData,
|
|||
|
||||
return nil
|
||||
}
|
||||
|
||||
// Generates a select query on the current tableName.
|
||||
func (e *expressionTableImpl) SELECT(projections ...projection) SelectStatement {
|
||||
return newSelectStatement(e, projections)
|
||||
}
|
||||
|
||||
// Creates a inner join tableName Expression using onCondition.
|
||||
func (e *expressionTableImpl) INNER_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
|
||||
return InnerJoinOn(e, table, onCondition)
|
||||
}
|
||||
|
||||
//func (s *expressionTableImpl) InnerJoinUsing(table ReadableTable, col1 column, col2 column) ReadableTable {
|
||||
// return INNER_JOIN(s, table, col1.EQ(col2))
|
||||
//}
|
||||
|
||||
// Creates a left join tableName Expression using onCondition.
|
||||
func (e *expressionTableImpl) LEFT_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
|
||||
return LeftJoinOn(e, table, onCondition)
|
||||
}
|
||||
|
||||
// Creates a right join tableName Expression using onCondition.
|
||||
func (e *expressionTableImpl) RIGHT_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
|
||||
return RightJoinOn(e, table, onCondition)
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) FULL_JOIN(table ReadableTable, onCondition BoolExpression) ReadableTable {
|
||||
return FullJoin(e, table, onCondition)
|
||||
}
|
||||
|
||||
func (e *expressionTableImpl) CROSS_JOIN(table ReadableTable) ReadableTable {
|
||||
return CrossJoin(e, table)
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue