我从光滑的测试中找到了这个例子:https:
//github.com/slick/slick/blob/master/slick-testkit/src/main/scala/com/typesafe/slick/testkit/tests/MapperTest.scala
sealed trait Bool
case object True extends Bool
case object False extends Bool
implicit val boolTypeMapper = MappedColumnType.base[Bool, String](
{ b =>
assertNotNull(b)
if(b == True) "y" else "n"
}, { i =>
assertNotNull(i)
if(i == "y") True else False
}
)
Run Code Online (Sandbox Code Playgroud)
但我正在尝试为org.joda.time.DateTime创建一个TypeMapper到/来自java.sql.Timestamp - 但没有太大的成功.Bool的例子非常特别,我在修改它时遇到了麻烦.Joda Time非常普遍 - 所以任何帮助都会非常感激.
为了清楚起见,我正在使用插值的sql"""从表格中选择colA,colB,其中id = $ {id}"""等等.在进行选择时,通过在隐式GetResult转换器中使用jodaDate类型,系统运行良好.
但是,对于插入,似乎没有办法进行隐式转换,或者它忽略了下面答案#1中提供的代码 - 与之前相同的错误:找不到参数pconv的隐式值:scala.slick.jdbc .SetParameter [(Option [Int],String,String,Option [org.joda.time.DateTime])]
我没有使用带有带注释的Table对象的Lifted样式Slick配置,这可能就是为什么它没有找到/使用TypeMapper
我们的webform站点中有一个用于预先输入文本字段的ajax listprovider.每个页面现在都请求listprovider.asmx/jsdebug,没有缓存参数等.
我们该怎么做呢?
我有一个工作的Scala解析器,但解决方案并不像我想的那样干净.问题是某些产品必须将空格视为令牌的一部分,但"更高级别"的产品应该能够忽略/跳过空白.
如果我使用扩展低级解析器的典型scala解析器模式,那么skipWhitespace设置将被继承,并且事情会很快变得混乱.
我想我最好不使用extends方法,而是在更高级别的解析器类中有一个低级解析器的实例 - 但是我不确定如何使这个工作,这样每个实例都会看到只有一个输入字符流.
这是最低级解析器的一部分 -
class VulgarFractionParser extends RegexParsers {
override type Elem = Char
override val whiteSpace = "".r
Run Code Online (Sandbox Code Playgroud)
然后我就像那样延伸
class NumberParser extends VulgarFractionParser with Positional {
Run Code Online (Sandbox Code Playgroud)
但是在这一点上,NumberParser必须像FractionParser一样显式处理空格.对于NumberParser它仍然是非常便于管理-但在上一级我真的希望能够只定义制作不使用空格作为分隔符,就像一个正常的regexParser会做.
一个例子是:
IBM 33.33/ 1200.00
or
IBM 33.33/33.50 1200.00
Run Code Online (Sandbox Code Playgroud)
第二个值有时有两个部分用"/"分隔,有时只有一个部分在斜线后面没有任何内容(甚至根本不包含斜杠).
def bidOrAskPrice = ("$"?) ~> (bidOrAskPrice1 | bidOrAskPrice2 | bidOrAskPrice3)
def bidOrAskPrice1 = number ~ ("/".r) ~ number ~ (SPACES) ^^ {
case a ~ slash ~ b ~ sp1 => BidOrAsk(a,Some(b))
}
def bidOrAskPrice2 = (number ~ …
Run Code Online (Sandbox Code Playgroud)