我有一个查询:
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)
}
但结果是一样的——空集。