2019-03-30 10:17:32 +01:00
|
|
|
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
|
2019-05-05 12:37:23 +02:00
|
|
|
|
|
|
|
|
RefIntColumnName(name string) *IntegerColumn
|
2019-06-05 17:15:20 +02:00
|
|
|
RefIntColumn(column Column) *IntegerColumn
|
|
|
|
|
RefStringColumn(column Column) *StringColumn
|
2019-05-05 12:37:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type expressionTableImpl struct {
|
2019-06-05 17:15:20 +02:00
|
|
|
readableTableInterfaceImpl
|
|
|
|
|
expression Expression
|
|
|
|
|
alias string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func newExpressionTable(expression Expression, alias string) expressionTable {
|
|
|
|
|
expTable := &expressionTableImpl{expression: expression, alias: alias}
|
|
|
|
|
|
|
|
|
|
expTable.readableTableInterfaceImpl.parent = expTable
|
|
|
|
|
|
|
|
|
|
return expTable
|
2019-03-30 10:17:32 +01:00
|
|
|
}
|
|
|
|
|
|
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) RefIntColumnName(name string) *IntegerColumn {
|
2019-06-05 17:15:20 +02:00
|
|
|
intColumn := NewIntegerColumn(name, false)
|
2019-05-13 12:33:11 +02:00
|
|
|
intColumn.setTableName(e.alias)
|
2019-04-03 11:03:07 +02:00
|
|
|
|
|
|
|
|
return intColumn
|
2019-03-30 10:17:32 +01:00
|
|
|
}
|
|
|
|
|
|
2019-06-05 17:15:20 +02:00
|
|
|
func (e *expressionTableImpl) RefIntColumn(column Column) *IntegerColumn {
|
|
|
|
|
intColumn := NewIntegerColumn(column.TableName()+"."+column.Name(), false)
|
2019-05-13 12:33:11 +02:00
|
|
|
intColumn.setTableName(e.alias)
|
2019-04-03 11:03:07 +02:00
|
|
|
|
|
|
|
|
return intColumn
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-05 17:15:20 +02:00
|
|
|
func (e *expressionTableImpl) RefStringColumn(column Column) *StringColumn {
|
|
|
|
|
strColumn := NewStringColumn(column.TableName()+"."+column.Name(), false)
|
2019-05-13 12:33:11 +02:00
|
|
|
strColumn.setTableName(e.alias)
|
2019-04-03 11:03:07 +02:00
|
|
|
return strColumn
|
2019-03-30 10:17:32 +01:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 14:37:51 +02:00
|
|
|
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-06-05 17:15:20 +02:00
|
|
|
err := e.expression.serialize(statement, out)
|
2019-03-30 10:17:32 +01:00
|
|
|
|
|
|
|
|
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)
|
2019-03-30 10:17:32 +01:00
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|