首页 > 解决方案 > Haskell HDBC 库:有没有一种优雅的方式在 [SqlValue] 和记录之间进行转换?

问题描述

由于我无法map超过记录,因此我发现的最佳方法是使用蛮力:

data Item = Item {
  vendor :: Int,
  lotNumber :: Int,
  description :: String,
  reserve :: Maybe Double,
  preSaleBids :: Maybe Double,
  salePrice :: Maybe Double,
  purchaser :: Maybe Int,
  saleID :: Maybe Int
}

hsToDb :: Item -> [SqlValue]
hsToDb (Item a b c d e f g h) = [toSql a, toSql b, toSql c, toSql d, toSql e, toSql f, toSql g, toSql h]

dbToHs :: [SqlValue] -> Item
dbToHs [a,b,c,d,e,f,g,h] = Item (fromSql a) (fromSql b) (fromSql c) (fromSql d) (fromSql e) (fromSql f) (fromSql g) (fromSql h)

这段代码看起来很难看,如果我改变Item记录的长度也需要更新,所以我想知道是否有一种聪明的方法来概括这个想法。

标签: haskellhdbc

解决方案


根据您使用的库,该类型(Int, Int, String, ...)可能已经有一个(如在 eg 中sqlite-simpleFromRow实例。如果您需要Item成为新类型,您可以使用GeneralizedNewtypeDeriving扩展免费获取该实例。除此之外,您当然可以定义自己的类型类/辅助方法以使其更加干燥。


推荐阅读