Skip to content

returning a Transaction for further usage #1227

@fredski02

Description

@fredski02

I'm trying to start a transaction and return it for later usage but i get lifetime issues because the lifetime of the transaction is tied to the client/connection. Is there a proper way to do this? I've tried wrapping the Transaction in a struct, using Box and tokio Mutex but nothing seemed to help

see below pseudo code.

#[async_trait]
trait myTrait {
  async fn start() -> Transaction {
         let mut client = self.get().await.unwrap(); // Get the client from the pool  
          let mut transaction = client.transaction().await.unwrap(); 
  
         // do some stuff with transaction
  
         transaction
  
  }
}

using the following core libs

tokio = { version = "1.38", features = ["macros", "rt-multi-thread", "signal"] }
tokio-postgres = { version = "0.7", features = ["runtime", "array-impls"] }
tokio-postgres-rustls = "0.13"
bb8 = "0.9"
bb8-postgres = "0.9"
warp = "0.3"
async-trait = "0.1"

Activity

sfackler

sfackler commented on Mar 20, 2025

@sfackler
Collaborator

You'd need to structure your API so the client stays checked out of the pool until the transaction ends.

fredski02

fredski02 commented on Mar 20, 2025

@fredski02
Author

You'd need to structure your API so the client stays checked out of the pool until the transaction ends.

You mean starting the transaction outside of my fn start?

sfackler

sfackler commented on Mar 20, 2025

@sfackler
Collaborator

That'd be one way to do it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

      Development

      No branches or pull requests

        Participants

        @sfackler@fredski02

        Issue actions

          returning a Transaction for further usage · Issue #1227 · rust-postgres/rust-postgres