首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Anorm:逃亡单曲

Anorm:逃亡单曲
EN

Stack Overflow用户
提问于 2016-05-14 01:35:31
回答 1查看 372关注 0票数 0

对于简单的db原油,我使用anorm,当输入参数包含单引号时,存在一个无声失败的问题。例如在用户表中姓“O‘’Brien”或“O‘’Neill”。我试图使用双引号来转义查询中的单引号,这消除了沉默失败,但是数据库条目中包含了"O''Brien“和”O‘Neill“两个姓氏。如何正确地避免单引号?

代码看起来像(对不起,请在SO中使用格式选项卡):

代码语言:javascript
复制
def insertNewUser(user: User): \/[Exception, UUID] = DB.withConnection { implicit connection =>
val updatedRowCount =
  SQL"""insert into user(id, email, first_name, surname)
        values (${user.id}::uuid, ${user.email}, ${sanitiseSqlQueryInput(user.firstName)},
        ${sanitiseSqlQueryInput(user.surname)})""".executeUpdate()
updatedRowCount match {
  case 1 =>
    log.debug(s"New user is successfully created [userId=${user.id.toString}]")
    \/-(user.id)
  case _ => -\/(new Exception(s"""Fail to create new user [id=${user.id.toString}] [email=${user.email}] [user=$user]"""))
}}

def sanitiseSqlQueryInput(s: String): String = s.replace("'", "''")

提前感谢!

我的回应可能是有限的,因为我还不能发表评论。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-14 02:10:55

使用SQL内插器,您不需要。Anorm为您创建一个预先准备好的语句。注意结果res0中的参数映射

代码语言:javascript
复制
scala> val name = "O'Neill"
name: String = O'Neill

scala> SQL"""SELECT ${name}"""
res0: anorm.SimpleSql[anorm.Row] = SimpleSql(anorm.SqlQuery$$anon$1@6e7633d,Map(_0 -> ParameterValue(O'Neill)),<function1>,false)
                                                                                  ^
                                                                 // --------------|

你可以简单地写:

代码语言:javascript
复制
SQL"""
  insert into user (id, email, first_name, surname) values 
  (${user.id}, ${user.email}, ${user.firstName}, ${user.surname})
   """.executeUpdate()
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37221552

复制
相关文章

相似问题

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