Skip to content

Commit

Permalink
Implement deleteRecord via primaryKeyCondition'
Browse files Browse the repository at this point in the history
This way it supports tables with arbitrary primary keys
  • Loading branch information
MonaMayrhofer committed Mar 3, 2024
1 parent db356aa commit 915a1f7
Showing 1 changed file with 14 additions and 4 deletions.
18 changes: 14 additions & 4 deletions IHP/ModelSupport.hs
Original file line number Diff line number Diff line change
Expand Up @@ -623,7 +623,8 @@ logQuery query parameters time = do
-- DELETE FROM projects WHERE id = '..'
--
-- Use 'deleteRecords' if you want to delete multiple records.
deleteRecord :: forall record table. (?modelContext :: ModelContext, Show (PrimaryKey table), Table record, HasField "id" record (Id' table), ToField (PrimaryKey table), GetModelByTableName table ~ record, Show (PrimaryKey table), ToField (PrimaryKey table)) => record -> IO ()
--
deleteRecord :: forall record table. (?modelContext :: ModelContext, Table record, Show (PrimaryKey table), HasField "id" record (Id record), GetTableName record ~ table, record ~ GetModelByTableName table) => record -> IO ()
deleteRecord record =
deleteRecordById @record record.id
{-# INLINABLE deleteRecord #-}
Expand All @@ -634,10 +635,19 @@ deleteRecord record =
-- >>> delete projectId
-- DELETE FROM projects WHERE id = '..'
--
deleteRecordById :: forall record table. (?modelContext :: ModelContext, Table record, ToField (PrimaryKey table), Show (PrimaryKey table), record ~ GetModelByTableName table) => Id' table -> IO ()
deleteRecordById :: forall record table. (?modelContext :: ModelContext, Table record, Show (PrimaryKey table), GetTableName record ~ table, record ~ GetModelByTableName table) => Id' table -> IO ()
deleteRecordById id = do
let theQuery = "DELETE FROM " <> tableName @record <> " WHERE id = ?"
let theParameters = PG.Only id
let (pkCols, paramPattern, theParameters) = case primaryKeyCondition' @record id of
[] -> error "Impossible"
[(colName, param)] -> (colName, "?", [param])
ps ->
( "(" <> intercalate "," (map fst ps) <> ")",
"(" <> intercalate "," (map (const "?") ps) <> ")",
map snd ps
)

let theQuery = "DELETE FROM " <> tableName @record <> " WHERE " <> pkCols <> " = " <> paramPattern

sqlExec (PG.Query . cs $! theQuery) theParameters
pure ()
{-# INLINABLE deleteRecordById #-}
Expand Down

0 comments on commit 915a1f7

Please sign in to comment.