1
Fork 0

Support autoincrement columns

This commit is contained in:
Matei Adriel 2024-01-06 19:57:28 +01:00
parent a937424514
commit c997e3196c
No known key found for this signature in database
4 changed files with 19 additions and 6 deletions

View file

@ -1587,13 +1587,16 @@ TODO: change style
> colConstraintDef :: Parser ColConstraintDef > colConstraintDef :: Parser ColConstraintDef
> colConstraintDef = > colConstraintDef =
> ColConstraintDef > ColConstraintDef
> <$> (optionMaybe (keyword_ "constraint" *> names)) > <$> optionMaybe (keyword_ "constraint" *> names)
> <*> (nullable <|> notNull <|> unique <|> primaryKey <|> check <|> references) > <*> (nullable <|> notNull <|> unique <|> primaryKey <|> check <|> references)
> where > where
> nullable = ColNullableConstraint <$ keyword "null" > nullable = ColNullableConstraint <$ keyword "null"
> notNull = ColNotNullConstraint <$ keywords_ ["not", "null"] > notNull = ColNotNullConstraint <$ keywords_ ["not", "null"]
> unique = ColUniqueConstraint <$ keyword_ "unique" > unique = ColUniqueConstraint <$ keyword_ "unique"
> primaryKey = ColPrimaryKeyConstraint <$ keywords_ ["primary", "key"] > primaryKey = do
> keywords_ ["primary", "key"]
> autoincrement <- optionMaybe (keyword_ "autoincrement")
> pure $ ColPrimaryKeyConstraint $ isJust autoincrement
> check = keyword_ "check" >> ColCheckConstraint <$> parens scalarExpr > check = keyword_ "check" >> ColCheckConstraint <$> parens scalarExpr
> references = keyword_ "references" >> > references = keyword_ "references" >>
> (\t c m (ou,od) -> ColReferencesConstraint t c m ou od) > (\t c m (ou,od) -> ColReferencesConstraint t c m ou od)

View file

@ -702,7 +702,8 @@ Try to do this when this code is ported to a modern pretty printing lib.
> <+> pcon con > <+> pcon con
> pcon ColNotNullConstraint = texts ["not","null"] > pcon ColNotNullConstraint = texts ["not","null"]
> pcon ColUniqueConstraint = text "unique" > pcon ColUniqueConstraint = text "unique"
> pcon ColPrimaryKeyConstraint = texts ["primary","key"] > pcon (ColPrimaryKeyConstraint autoincrement) =
> texts $ ["primary","key"] ++ ["autoincrement"|autoincrement]
> pcon (ColCheckConstraint v) = text "check" <+> parens (scalarExpr d v) > pcon (ColCheckConstraint v) = text "check" <+> parens (scalarExpr d v)
> pcon (ColReferencesConstraint tb c m u del) = > pcon (ColReferencesConstraint tb c m u del) =
> text "references" > text "references"

View file

@ -44,6 +44,7 @@
> ,IdentityWhen(..) > ,IdentityWhen(..)
> ,SequenceGeneratorOption(..) > ,SequenceGeneratorOption(..)
> ,ColConstraintDef(..) > ,ColConstraintDef(..)
> ,AutoincrementClause
> ,ColConstraint(..) > ,ColConstraint(..)
> ,TableConstraint(..) > ,TableConstraint(..)
> ,ReferenceMatch(..) > ,ReferenceMatch(..)
@ -575,11 +576,13 @@ I'm not sure if this is valid syntax or not.
> -- (Maybe [ConstraintCharacteristics]) > -- (Maybe [ConstraintCharacteristics])
> deriving (Eq,Show,Read,Data,Typeable) > deriving (Eq,Show,Read,Data,Typeable)
> type AutoincrementClause = Bool
>
> data ColConstraint = > data ColConstraint =
> ColNullableConstraint > ColNullableConstraint
> | ColNotNullConstraint > | ColNotNullConstraint
> | ColUniqueConstraint > | ColUniqueConstraint
> | ColPrimaryKeyConstraint > | ColPrimaryKeyConstraint AutoincrementClause
> | ColReferencesConstraint [Name] (Maybe Name) > | ColReferencesConstraint [Name] (Maybe Name)
> ReferenceMatch > ReferenceMatch
> ReferentialAction > ReferentialAction
@ -730,6 +733,6 @@ I'm not sure if this is valid syntax or not.
> -- | Comment. Useful when generating SQL code programmatically. The > -- | Comment. Useful when generating SQL code programmatically. The
> -- parser doesn't produce these. > -- parser doesn't produce these.
> data Comment = BlockComment String > newtype Comment = BlockComment String
> deriving (Eq,Show,Read,Data,Typeable) > deriving (Eq,Show,Read,Data,Typeable)

View file

@ -332,7 +332,13 @@ todo: constraint characteristics
> "create table t (a int primary key);" > "create table t (a int primary key);"
> $ CreateTable [Name Nothing "t"] > $ CreateTable [Name Nothing "t"]
> [TableColumnDef $ ColumnDef (Name Nothing "a") (TypeName [Name Nothing "int"]) Nothing > [TableColumnDef $ ColumnDef (Name Nothing "a") (TypeName [Name Nothing "int"]) Nothing
> [ColConstraintDef Nothing ColPrimaryKeyConstraint]]) > [ColConstraintDef Nothing (ColPrimaryKeyConstraint False)]])
> ,(TestStatement ansi2011
> "create table t (a int primary key autoincrement);"
> $ CreateTable [Name Nothing "t"]
> [TableColumnDef $ ColumnDef (Name Nothing "a") (TypeName [Name Nothing "int"]) Nothing
> [ColConstraintDef Nothing (ColPrimaryKeyConstraint True)]])
references t(a,b) references t(a,b)
[ Full |partial| simepl] [ Full |partial| simepl]