SLICK 3.0 - 多个查询相互依赖 - db.run(action)

2023-12-22

我是 Slick 3 的新手,到目前为止我已经了解 db.run 是异步调用。一旦 Future 返回,.map 或 .flatMap 就会运行。

下面我的代码中的问题是所有子查询都不起作用(嵌套db.run)。

从概念上讲,我没有得到什么?执行下面这种代码是否有效?基本上在第一个查询的 .map 中,我根据第一个查询执行一些操作。

我到处都看到带yield的for循环,这是唯一的出路吗?我的代码中的问题与返回的 Future 值有关吗?

val enterprises = TableQuery[Enterprise]
val salaries = TableQuery[Salary]

//Check if entered enterprise exists 
val enterpriseQS = enterprises.filter(p => p.name.toUpperCase.trim === salaryItem.enterpriseName.toUpperCase.trim).result

val result=db.run(enterpriseQS.headOption).map(_ match 
{
    case Some(n) => {
      //if an enterprise exists use the ID from enterprise (n.id) when adding a record to salary table
      val addSalary1 = salaries += new SalaryRow(0, n.id, salaryItem.worker)
      db.run(addSalary1)
    }
    case None =>  {
        //if an enterprise with salaryItem.enterpriseName doesn't exist, a new enterprise is inserted in DB
        val enterpriseId = (enterprises returning enterprises.map(_.id)) += EnterpriseRow(0, salaryItem.enterpriseName)
        db.run(enterpriseId).map{
            e => {
                val salaryAdd2 = salaries += new SalaryRow(0, e, salaryItem.worker)
                db.run(salaryAdd2)
            }
        }
    }
})

下面我的代码中的问题是所有子查询都不起作用(嵌套db.run)

我怀疑你最终会嵌套Future[R]结果。不过我还没有调查过。因为...

从概念上讲,我没有得到什么?

我解决这个问题的方法是考虑结合DBIO[R]。这可能是有帮助的概念。

你正在做的就是尝试运行每个action(查询、插入...)单独。 相反,将各个操作合并为一个操作并运行它。

我将主要逻辑重写为:

  val action: DBIO[Int] = for {
    existingEnterprise <- enterpriseQS.headOption
    rowsAffected       <- existingEnterprise match {
      case Some(n) => salaries += new SalaryRow(0, n.id, salaryItem.worker)
      case None    => createNewEnterprise(salaryItem)
    }
  } yield rowsAffected

For the None我会创建一个辅助方法:

  def createNewEnterprise(salaryItem: SalaryItem): DBIO[Int] = for {
    eId          <- (enterprises returning enterprises.map(_.id)) += EnterpriseRow(0, salaryItem.enterpriseName)
    rowsAffected <- salaries += new SalaryRow(0, eId, salaryItem.worker)
  } yield rowsAffected

最后,我们可以运行:

  val future: Future[Int] = db.run(action)
  // or db.run(action.transactionally)    

  val result = Await.result(future, 2 seconds)

  println(s"Result of action is: $result")

下半场我写的博客文章 http://underscore.io/blog/posts/2015/07/14/upsert.html更多地谈论这个。

我使用的代码是:https://github.com/d6y/so-31471590 https://github.com/d6y/so-31471590

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SLICK 3.0 - 多个查询相互依赖 - db.run(action) 的相关文章

随机推荐

  • wxHaskell标签无法显示全文

    我正在 Windows XP 上使用 Hello World 测试 wxHaskell http www haskell org haskellwiki WxHaskell Quick start http www haskell org
  • jQuery、html5、append()/appendTo() 和 IE

    如何复制 创建一个 html5 页面 确保添加了来自 remysharp com 2009 01 07 html5 enabling script 的脚本 以便 IE 能够注意到这些标签 创建硬编码 section section tag
  • Bootstrap 4 个选项卡

    好的 我正在尝试使用 bootstrap 4 制作动态选项卡 如下所示 https codepen io jek pen BoWNRy 不是我写的 无论如何 我在本地粘贴此代码都不起作用 我显示了 3 个选项卡 但我只能在第一个选项卡中看到
  • 有没有办法在运行时修改Linux C程序中函数的代码?

    简单来说 我们有两个类似的函数 void f1 printf d 123 void f2 printf d 124 现在我们在main中调用f1 它会打印123 编译时 反汇编f1可能是这样的 08048424
  • Python 的日、月、年时间戳

    是否可以在 Python 中创建仅包含日期对象中的日 月和年的 UNIX 时间戳 秒数 我本质上是在寻找午夜时的时间戳 小时 分钟和秒为 0 Thanks gt gt gt import time gt gt gt import datet
  • Python for 循环中捕获异常

    我有以下 for 循环 for batch in loader do something with batch 从加载器中提取批处理时 我的循环有时会失败 我想做的是类似于下面的代码片段 但我希望能够继续循环下一个值 而不是跳过其余的值 e
  • LINQ to SQL - 没有可用的添加方法

    我创建了一个 LINQ to SQL 数据上下文 其中包含一个数据表 我试图简单地将一条新记录插入该表中 我遇到的问题是 LINQ 没有提供 Add 方法来传递新记录 我见过无数有 Add 方法的例子 但我似乎无法理解它 我完全错过了什么还
  • 当 Node 后端 (MongoDB) 中的状态发生变化时通知 Angular 前端

    当 MongoDB 中的状态发生变化时 我希望实时更新 Angular 前端 我的选择是什么 除了例如 还有其他方法吗 使用socket io 场景 用户创建提醒 设置电子邮件到达其邮箱的日期 现在 为了添加和删除提醒 我可以在前端模拟实时
  • Android EditText 空间验证

    我的 Android 应用程序中有一个 Edittext 我不想允许用户输入第一个空格字符 但是输入其他字符后用户也可以输入空格 I used
  • 告诉 Ctags 不要解析评论中的内容

    当我生成 ctags 文件时 它似乎也在解析注释中的内容 例如 使用 Vim 的插件 Tagbar 我可以在函数列表中看到不存在的函数 例如 is in just 这里发生的情况是 ctags 正在进入评论并发现以下内容 This func
  • 如何使用 CSS 使某个区域不可点击?

    假设我有包含一些链接和图像的包装 div 有什么方法可以仅使用 CSS 立即停用它吗 审查答案后 我放弃了只用 CSS 就能实现的想法 jQuery blockUI 插件就像魅力一样 有一个 CSS 规则 pointer events no
  • Laravel:如何从查询结果中获取模型?

    假设我有一个查询 除其他外 返回用户 ID 该查询是使用DB table 而不是使用模型 因此 我得到了一个集合 其中包含每个检索到的行的数组 如下所示 user id calculated data 1 123 2 111 3 222 假
  • 防止 lxml 在 ` 中转义 & 符号 ` 写入文件时

    我需要向现有 XML 元素添加一个属性 该属性必须包含 实体内的字符 例如 x0d 将修改后的 XML 写入文件时 变成 amp 从而摧毁该实体 import lxml etree as et e et Element a e set at
  • 基于公共密钥分析数据的简单方法

    处理映射到特定键的所有记录并输出该数据的多个记录的最简单方法是什么 例如 综合示例 假设我的密钥是日期 值是带有测量温度的当天时间戳 我想将一天内的温度分为高 平均 低 同样 低于 高于平均值 1 个标准偏差 输出将是具有新分类的原始温度
  • 在 Android 中创建和处理应用程序超时

    我想知道处理应用程序超时的最佳方法是什么 例如 PayPal 我希望用户选择 1 5 或 15 分钟的超时时间 这样当他们打开应用程序时 他们必须再次登录 我的 onResume 方法 Override public void onResu
  • 按 15 分钟间隔对数据集进行分组

    我正在尝试为我们的内部公司系统建立平均会话量 问题是范围大约向后三个月 我想按 15 分钟间隔对这整组大数据进行分组 因此输出将如下所示 interval sess avg 12 00 12 15 300 12 15 12 30 350 e
  • FromBody 值获取 null

    这是 Asp Net Webform 应用程序这是我的 Apicontroller 中的 POST 方法 public void Post FromBody string value 我正在使用 fiddler 后期处理 我就是这么实验的
  • 更改 FloatingActionButton 的背景?

    我试图在 XML 中将 FAB 的背景设置为不同的颜色 我知道我可以在代码中做到这一点 但这也需要我进行大量不方便的重构
  • ListView 显示项目但不显示组

    我正在创建一个简单的模式对话框 其中包含列表视图 当我将项目添加为组的一部分时 项目将显示 但组标题不会显示 我一直在尝试在构造函数中使用一些虚拟对象 这是代码 Initialize and create columns public Co
  • SLICK 3.0 - 多个查询相互依赖 - db.run(action)

    我是 Slick 3 的新手 到目前为止我已经了解 db run 是异步调用 一旦 Future 返回 map 或 flatMap 就会运行 下面我的代码中的问题是所有子查询都不起作用 嵌套db run 从概念上讲 我没有得到什么 执行下面