首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >toSql (database.HDBC)的使用

toSql (database.HDBC)的使用
EN

Stack Overflow用户
提问于 2018-04-03 13:22:16
回答 1查看 75关注 0票数 0

我不知道如何使用来自database.HDBC的database.HDBC。

代码语言:javascript
复制
*Main> toSql "foobar"
SqlString "foobar"

在此之前,我觉得可以接受,我有一些SqlString类型的东西

现在,尝试一下往返旅行:

代码语言:javascript
复制
*Main> fromSql $ toSql "foobar"

<interactive>:4:1: error:
    * Non type-variable argument
        in the constraint: Data.Convertible.Base.Convertible SqlValue a
      (Use FlexibleContexts to permit this)
    * When checking the inferred type
        it :: forall a. Data.Convertible.Base.Convertible SqlValue a => a

好的,我根据这个线程FlexibleContexts打开Haskell : Use -XFlexibleContexts to permit this?

代码语言:javascript
复制
*Main> :set -XFlexibleContexts
*Main> fromSql $ toSql "foobar"

<interactive>:8:1: error:
    * No instance for (Data.Convertible.Base.Convertible SqlValue ())
        arising from a use of `it'
    * In the first argument of `print', namely `it'
      In a stmt of an interactive GHCi command: print it

不过,KO,我在这里了解到,无论往返创建什么类型,这个东西对打印来说都不是一个有效的论据。

我正在检查类型:

代码语言:javascript
复制
*Main> res = fromSql $ toSql "foobar"
*Main> :t res
res :: Data.Convertible.Base.Convertible SqlValue a => a

我迷路了..。我希望有一些像char或String的东西。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-03 14:20:16

您只需要添加一个类型注释,就可以成功地完成打字机操作:

代码语言:javascript
复制
λ> fromSql $ toSql "foobar" :: String
"foobar"

如果您将其与更多的上下文代码一起使用,则如果可以推断注释,则可以跳过注释,例如:

代码语言:javascript
复制
λ> putStrLn $ fromSql $ toSql "foobar"
foobar

由于putStrLn具有String -> IO ()类型,因此将自动为您推断该类型。

试图给出一些关于为什么需要这样做的直觉:

toSql的类型是:

代码语言:javascript
复制
toSql :: Convertible a SqlValue => a -> SqlValue

注意,结果类型(SqlValue)没有任何参数说明它包含什么类型--它只是一个黑匣子,可以是字符串、数字等。

代码语言:javascript
复制
fromSql :: Convertible SqlValue a => SqlValue -> a

...we可以看到它接受这个黑匣子,并且必须从它返回一个特定类型的值。它不能将这种类型限制为StringInt,因为它必须能够根据黑匣子中的内容返回不同的类型,而黑匣子本身在编译时不显示任何关于它内部的信息,所以它不能利用这一点。

因此,它唯一可能的返回类型是一些a (服从约束Convertible SqlValue a),因此您必须添加类型约束,以强制将其强制到打字机。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49631208

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档