module Hasura.Backends.MSSQL.FromIr.SelectIntoTempTable
( toSelectIntoTempTable,
)
where
import Hasura.Backends.MSSQL.Instances.Types ()
import Hasura.Backends.MSSQL.Types.Internal as TSQL
import Hasura.Prelude
import Hasura.RQL.Types.Column qualified as IR
import Hasura.SQL.Backend
toSelectIntoTempTable :: TempTableName -> TableName -> [IR.ColumnInfo 'MSSQL] -> SITTConstraints -> SelectIntoTempTable
toSelectIntoTempTable :: TempTableName
-> TableName
-> [ColumnInfo 'MSSQL]
-> SITTConstraints
-> SelectIntoTempTable
toSelectIntoTempTable TempTableName
tempTableName TableName
fromTable [ColumnInfo 'MSSQL]
allColumns SITTConstraints
withConstraints = do
SelectIntoTempTable :: TempTableName
-> [UnifiedColumn]
-> TableName
-> SITTConstraints
-> SelectIntoTempTable
SelectIntoTempTable
{ $sel:sittTempTableName:SelectIntoTempTable :: TempTableName
sittTempTableName = TempTableName
tempTableName,
$sel:sittColumns:SelectIntoTempTable :: [UnifiedColumn]
sittColumns = (ColumnInfo 'MSSQL -> UnifiedColumn)
-> [ColumnInfo 'MSSQL] -> [UnifiedColumn]
forall a b. (a -> b) -> [a] -> [b]
map ColumnInfo 'MSSQL -> UnifiedColumn
columnInfoToUnifiedColumn [ColumnInfo 'MSSQL]
allColumns,
$sel:sittFromTableName:SelectIntoTempTable :: TableName
sittFromTableName = TableName
fromTable,
$sel:sittConstraints:SelectIntoTempTable :: SITTConstraints
sittConstraints = SITTConstraints
withConstraints
}
columnInfoToUnifiedColumn :: IR.ColumnInfo 'MSSQL -> UnifiedColumn
columnInfoToUnifiedColumn :: ColumnInfo 'MSSQL -> UnifiedColumn
columnInfoToUnifiedColumn ColumnInfo 'MSSQL
colInfo =
case ColumnInfo 'MSSQL -> ColumnType 'MSSQL
forall (b :: BackendType). ColumnInfo b -> ColumnType b
IR.ciType ColumnInfo 'MSSQL
colInfo of
IR.ColumnScalar ScalarType 'MSSQL
t ->
UnifiedColumn :: ColumnName -> ScalarType -> UnifiedColumn
UnifiedColumn
{ $sel:name:UnifiedColumn :: ColumnName
name = ColumnInfo 'MSSQL -> Column 'MSSQL
forall (b :: BackendType). ColumnInfo b -> Column b
IR.ciColumn ColumnInfo 'MSSQL
colInfo,
$sel:type':UnifiedColumn :: ScalarType
type' = ScalarType 'MSSQL
ScalarType
t
}
IR.ColumnEnumReference {} ->
UnifiedColumn :: ColumnName -> ScalarType -> UnifiedColumn
UnifiedColumn
{ $sel:name:UnifiedColumn :: ColumnName
name = ColumnInfo 'MSSQL -> Column 'MSSQL
forall (b :: BackendType). ColumnInfo b -> Column b
IR.ciColumn ColumnInfo 'MSSQL
colInfo,
$sel:type':UnifiedColumn :: ScalarType
type' = ScalarType
TextType
}