• @[email protected]
    link
    fedilink
    28 months ago

    As the other commenter said, the Jetbrains IDEs do this perfectly fine. Although I’d also argue that if you’re working with SQL from within another language already, a DSL wrapper is probably gonna be the better way to go about this.

    • @[email protected]
      link
      fedilink
      2
      edit-2
      8 months ago

      Unfortunately RustRover is still garbage for actual usage. And I refuse to use an ORM when I can just write the SQL in a more common syntax that everyone understands across every language instead of whatever inefficient library-of-the-week there is. Raw SQL is fine and can be significantly more performant. Don’t be scared.

      • @[email protected]
        link
        fedilink
        28 months ago

        I’m not talking full blown ORM here, not a fan of those either. I’m talking about some light weight wrapper that basically just assembles SQL statements for you, while giving you just a little more type safety and automatic protection against SQL injection, and not sacrificing any performance. I’m coming from the JVM world, where Jooq and Exposed are examples of that kind of thing.

        • @[email protected]
          link
          fedilink
          1
          edit-2
          8 months ago

          I’m currently using SQLx which you write raw queries in and it validates them against a currently-running db, using the description of the tables to build the typing for the return type instead of relying on the user. It makes it pretty hard to write anything that supports injection

          • @[email protected]
            link
            fedilink
            28 months ago

            Oh, that sounds really cool! At what time does this validation happen? While you code, or later at build time?

            • @[email protected]
              link
              fedilink
              38 months ago

              Happens at compile time! It’s relatively quick. You can also run a command to write the query results to file for offline type checking which is mostly useful for CI