Nano Hash - криптовалюты, майнинг, программирование

Как повторно использовать scala slick withSession { неявный сеанс: Session => блок кода

У меня есть этот код в scala с использованием slick

def insertTask(task: Task) = {
  conn.dbObject withSession { implicit session: Session =>
    tasks.insert(task)
  }
}

вроде работает :)

Теперь у меня будет также код для readTask, и я не хочу дублировать код для withSession { implicit....

Поэтому я подумал сделать это:

def doWithConn(dbConn: DBConnection, doThisCodeBlock: => Unit)(implicit session: Session) = {
  dbConn.dbObject withSession { implicit session: Session =>
    doThisCodeBlock
  }
}

и теперь мой код выглядит так

def insertTask(task: Task) = {
  doWithConn(conn, tasks.insert(task)) // here i get the following complication error
}

однако я получаю следующую ошибку компиляции:

Ошибка: (36, 34) не удалось найти неявное значение для параметра session: scala.slick.jdbc.JdbcBackend#SessionDef doWithConn(conn, tasks.insert(task)) ^

Я не знаю, как передать session из метода insertTask. Как я могу передать его и исправить эту ошибку компиляции?

Спасибо

17.12.2014

  • В вашем методе doWithConn вам не нужно передавать Session, вы создаете его в теле метода. 17.12.2014
  • @EndeNeu Я не думаю, что понимаю (я удалил (implicit session: Session), я все еще получаю ту же ошибку компиляции, но не уверен, что вы это имели в виду ..) 17.12.2014

Ответы:


1

withSession — это метод, который принимает функцию из сеанса во что угодно в качестве аргумента. syntax { implicit session => } просто делает сеанс неявным. Но вы также можете просто передать функцию:

val yourBlock: Session => ... = ...

db.withSession(yourBlock)

Не нужно оборачивать его, просто используйте его как есть :).

Крис

17.12.2014
  • Когда я попытался определить что-то вроде этого: val insertTaskInternal : Session => Unit = tasks.insert(task), я получаю Error:(32, 59) not found: value task val insertTaskInternal : Session => Unit = tasks.insert(task) ^. (он не может найти вставку метода для задач) он отлично работает, когда он инкапсулирован в conn.dbObject withSession { implicit session: Session => 17.12.2014
  • попробуйте .insert(task)(_) превратить второй список аргументов метода в аргумент функции. Кроме этого, мне нужно было бы увидеть полный код и полное сообщение. 18.12.2014
  • имеет смысл! я плохо разбираюсь в этом, у меня все еще есть проблемы с реализацией yourBlock, я пробовал это так (в случае, если ваш блок - это схема удаления) val deleteSchemeFunc: (Session => Unit) = { s: Session => tasks.ddl.drop }, но я получаю ошибку компиляции: Error:(49, 71) could not find implicit value for parameter session: scala.slick.jdbc.JdbcBackend#SessionDef val deleteSchemeFunc: (Session => Unit) = { s: Session => tasks.ddl.drop } ^ 18.12.2014
  • ок нашел ответ! :) val deleteSchemeFunc: (Session => Unit) = { session: Session => tasks.ddl.drop(session) } 18.12.2014
  • должен быть идентичен val deleteSchemeFunc = tasks.ddl.drop(_) 18.12.2014
  • Кроме того, все это не является чем-то специфичным для Slick. Это чистый синтаксис Scala и вопросы семантики. Возможно, есть какая-то общая литература по Scala, объясняющая все это. 18.12.2014

  • 2

    Я думаю, проблема в том, что ваш doThisCodeBlock не имеет представления о сеансе, который ему передается. Я думаю, что лучше просто использовать каррирование для повторного использования операторов, использующих сеанс:

    def insertTaskStatement(task: Task)(implicit session: Session) = {
        tasks.insert(task)
    }
    
    def insertOtherThingStatement(otherThing: OtherThing)(implicit session: Session) = {
        things.insert(otherThing)
    }
    
    def insertTaskAndOtherThing(task: Task,otherThing: OtherThing) = {
      conn.dbObject withSession { implicit session: Session =>
        insertTaskStatement(task)
        insertOtherThingStatement(otherThing)
      }
    }
    
    17.12.2014
    Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..