3

我有一个查询:

val sql = """select
                   id,
                   clientName
             from
                  partnerClients
             where
                  partnerName = ?
          """

我从 excel 文件中读取了 partnerName 并为每个我执行了函数:

case class Partner(name: String)
case class Client(id: Int, name: String)

def queryPartnerClients(partnerName: String) = Query[String, Client](sql, None).toQuery0(partnerName)

def getPartnerClients(partner: Partner): IO[Vector[Client]] =  partnerClients(partner.name)                                             
                                                              .to[Vector]
                                                              .transact(xa)

我使用了这个常见问题解答(如何将任意 SQL 字符串转换为 Query/Query0)

当我从 excel 中获取合作伙伴名称时,问题是得到空结果,但如果我在代码中指定相同的合作伙伴名称,例如,它可以工作:

def partnerClients(partnerName: String) = {
    val temp = "Partner Name"
    Query[String, Client](sql, None).toQuery0(temp)
}

我认为这是编码的问题,我试图修复它

def partnerClients(partnerName: String) = {
    val temp = new String(partner.getBytes("Windows-1251"), "UTF-8")
    Query[String, Client](sql, None).toQuery0(temp)
}

但结果是一样的——空集。

4

1 回答 1

1

我使用此答案打开日志记录,发现我发送的参数包含空格。修剪功能修复它

于 2020-01-29T11:50:06.600 回答