У меня есть таблица, определенная как
CREATE TABLE users (id SERIAL PRIMARY KEY, val BYTEA);
Затем я хочу сериализовать мою структуру данных с помощью binary
и сохранить в таблице, а затем извлечь и десериализовать обратно.
{-# LANGUAGE OverloadedStrings, DeriveAnyClass #-}
import Control.Monad (forM_)
import Data.Binary (encode, decode, Binary)
import Database.PostgreSQL.Simple
import GHC.Generics (Generic)
data User = { name :: Text, email :: Text } deriving (Show, Generic, Binary)
main = do
conn <- connect --...
let encoded = encode User {name = "me", email = "me@home.net" }
execute conn "INSERT INTO users(val) values(?)" $ Only encoded
rs <- query_ conn "SELECT id, val FROM users"
forM_ rs $ \(id,val) ->
putStrLn $ (show (id :: Int)) ++ ": " ++ show (decode val :: User)
Но я получаю ошибку Data.Binary.Get.runGet at position 0: not enough bytes
.
Запрос
SELECT * FROM users;
дает
id | val
----+-----
1 | \x
Я не могу понять, как сопоставить ByteString
с 'BYTEA`s. Согласно документам все должно быть в порядке. Что я делаю не так?