Learn Drizzle ORM in 13 mins (crash course)

Поділитися
Вставка
  • Опубліковано 10 січ 2025

КОМЕНТАРІ • 52

  • @neondatabase
    @neondatabase  11 місяців тому +11

    If you enjoyed watching this video, make sure to like and subscribe so you don't miss out on any future videos.
    If you'd like to learn more about using Drizzle with Preview Environments, check out our previous video: ua-cam.com/video/EOVa68Uviks/v-deo.html
    Drizzle ORM Docs: orm.drizzle.team/docs/overview
    Neon Serverless Driver: github.com/neondatabase/serverless

  • @bengribbin6440
    @bengribbin6440 11 місяців тому +13

    Excellent and timely tutorial! Would love to see an example of using custom types (adding vector embeddings) through drizzle to Neon too

    • @neondatabase
      @neondatabase  11 місяців тому +1

      Glad you found it helpful!
      > Would love to see an example of using custom types (adding vector embeddings) through drizzle to Neon too
      This is a great idea! Thank you for sharing your feedback
      - Mahmoud

  • @PlayerRPG85
    @PlayerRPG85 10 місяців тому +2

    This is the best intro to Drizzle I've ever seen

  • @ThunderboltPath
    @ThunderboltPath 11 місяців тому +8

    Very helpful for understanding Drizzle, thanks!

    • @neondatabase
      @neondatabase  11 місяців тому +1

      We're glad you found it helpful!

  • @siyedyoussef3202
    @siyedyoussef3202 11 місяців тому +4

    very informative video and on the target 🎯 love too see more of this types of videos

    • @neondatabase
      @neondatabase  11 місяців тому

      We're glad you found it helpful!

  • @DanielDrejerDK
    @DanielDrejerDK 11 місяців тому +5

    Well done!
    Only thing I would have loved to see along with this, would be how to retrieve only a few specific columns, rather than everything. :)

    • @neondatabase
      @neondatabase  11 місяців тому +10

      If you'd like to do a partial select, you can do it this way
      const result = await db.select({
      field1: users.id,
      field2: users.name,
      }).from(users);
      orm.drizzle.team/docs/select#partial-select

  • @srijonp4
    @srijonp4 10 місяців тому +5

    Nice, I am going to try drizzle now.

  • @JosefuDorayvu
    @JosefuDorayvu Місяць тому

    Holy cows! You are a legend for this banger of a crash course, cheers!

  • @VincentFulco
    @VincentFulco 10 місяців тому +3

    very cool and practical. Thanks!

  • @eliastouil7686
    @eliastouil7686 7 місяців тому +1

    This is a great intro thank you! Came here from Fireship's vid.

  • @8bitWatermelon
    @8bitWatermelon 3 місяці тому +1

    Really enjoyed the video, currently learning to use drizzle for projects. For anyone who is trying to use drizzle-kit generate with cli params. The code in the video will not work. This is my solution after many trials and errors.
    "db:generate": "drizzle-kit generate --dialect postgresql --schema ./src/db/schema.ts --out=./src/db/migrations"
    Thank you.

  • @marta84-k5i
    @marta84-k5i 9 місяців тому +1

    thank you, this was a nice one, hope there is another how relationships works in drizzle, tyy

  • @javierfuentesmora1814
    @javierfuentesmora1814 9 місяців тому +6

    do you need to close the db connection ?

  • @JissJoy-zt1is
    @JissJoy-zt1is 6 місяців тому +1

    Great stuff! It was really informative. I had a slightly different question. 😅
    The editor folder icons and theme, which extension are you using? I really liked em!
    Would be glad if you could share it.

  • @anirudhsinghbhadauria4034
    @anirudhsinghbhadauria4034 10 місяців тому +4

    Nice file management!

  • @omkar._.k
    @omkar._.k 10 місяців тому +2

    Hello Neon
    I just wanted to know something. When I generat a new db migrations like you showed it at 4:37 , it is not accepting the syyntax of sql file . I have installed postgres correctly and also not missing any steps in dependencies. Using VS Code . I hope you can help with a reply!!

    • @neondatabase
      @neondatabase  10 місяців тому +1

      Hey!
      > it is not accepting the syyntax of sql file
      Do you mind sharing more details? What kind of issues are you running into? What's the error message?

  • @eliuddyn
    @eliuddyn 10 місяців тому +2

    Amazing 🔥🔥

  • @haydonge5328
    @haydonge5328 4 місяці тому +1

    lots content for drizzle have been changed. Hope to update it with learning course.

  • @LarsRyeJeppesen
    @LarsRyeJeppesen 10 місяців тому +1

    Great stiff. How to deal with mysql pools for i stance? Does drizzle open amd close a connection fir each request?

    • @neondatabase
      @neondatabase  10 місяців тому

      Drizzle doesn't automatically handle the opening and closing of connections for each request. This needs to be handled by the developer, which depends on which database driver they're using

    • @LarsRyeJeppesen
      @LarsRyeJeppesen 10 місяців тому

      @@neondatabase yes thanks I saw now, using mysql2 pool connection. Loving this ORM

  • @mdsalahuddin2841
    @mdsalahuddin2841 10 місяців тому +1

    how can we retrieve large scale json file generated from application like excalidraw ?

  • @carlotadias9335
    @carlotadias9335 2 місяці тому

    great video
    thank you 😊😊😊😊😊😊😊😂😂

  • @abhinasregmi9742
    @abhinasregmi9742 9 місяців тому +1

    You look so happy 😊 😊

  • @TristanRemy
    @TristanRemy 10 місяців тому +1

    Awesome content! Just one question which might look stupid : in your package.json, why use bun for migrate/seed and bunx for format/lint with biome being a devDependency ?

    • @neondatabase
      @neondatabase  10 місяців тому +1

      Not stupid at all! This is how it's recommended to use in the Biome docs
      biomejs.dev/guides/getting-started/#usage
      The package is installed in the project so that the editor can format on save. I like including it in the project so that if someone clones the repo they can easily get up and running
      - Mahmoud

  • @raine-works
    @raine-works 7 місяців тому

    What theme and icons are you using for VSCode?

  • @mouradbougarne1162
    @mouradbougarne1162 10 місяців тому

    I tried to ask on their Discord server but no answer.
    Does drizzle support add unique constraint based on two columns? `To make a column unique only based on another column, a playlist title is unique per user ID.

  • @yoskokleng3658
    @yoskokleng3658 26 днів тому

    Hello sir,
    please help tell me how to run generate and migrate commands for a schema other than the default public schema, without using pgSchema (as it is fixed)?
    Also, could you tell me how to establish a connection with Drizzle ORM using dynamic schemas?
    Thanks

  • @abhisekdas9976
    @abhisekdas9976 7 місяців тому

    What vscode icon pack are you using?

  • @etj1237
    @etj1237 5 місяців тому

    Please Please Please tell us what theme and icon pack you're using !!!! 🙏🙏🙏🙏🙏

    • @neondatabase
      @neondatabase  5 місяців тому +1

      GitHub Dark default (theme) + Symbols (icons)
      - Mahmoud

  • @asadmehboob1300
    @asadmehboob1300 10 місяців тому

    please help me to generate generic repository pattern using drizzle or dynamic query

  • @tradecate
    @tradecate 10 місяців тому

    If I use neon branches, do I still have to create migrations? Planetscale explains that branches negate migrations so use db push instead of db migrate (for prisma)

    • @neondatabase
      @neondatabase  10 місяців тому

      Neon doesn't manage migrations for you as of today. So you will need to write them (or generate them depending on your framework of choice) and apply them in a Ci/CD pipeline or before your project's build step.
      Merging branches is something we're thinking about. But we don't have an exact ETA
      - Mahmoud

  • @sudiptapaul278
    @sudiptapaul278 10 місяців тому

    export const db = drizzle(sql)
    This line is showing me the error: "Argument of type 'NeonQueryFunction' is not assignable to parameter of type 'NeonQueryFunction'.
    Types of property 'transaction' are incompatible.

    • @hamzasaleem2
      @hamzasaleem2 10 місяців тому

      const sql: NeonQueryFunction = neon(process.env.DATABASE_URL);
      this will fix it!

  • @faizanhaider
    @faizanhaider 10 місяців тому +3

    Coming from #fireship 😉

  • @linodil
    @linodil 10 місяців тому +1

    Why did you choose Hono over Elysiajs. Elysia has been longer in the game and is faster than Hono.

    • @neondatabase
      @neondatabase  10 місяців тому +1

      No reason is in particular. Both are awesome!
      - Mahmoud

    • @jitxhere
      @jitxhere 10 місяців тому

      Hono can be deployed to like Workers, Vercel, Node.js etc.... Elysia main focus is bun right and also it is new right?? Also does any hosting support it??

  • @WorkerThreads
    @WorkerThreads 11 місяців тому +1

    What is ide ?

    • @neondatabase
      @neondatabase  11 місяців тому +2

      GitHub Dark theme + the "Symbols" icons extension
      - Mahmoud

  • @hakuna_matata_hakuna
    @hakuna_matata_hakuna 6 місяців тому

    no local dev?

  • @Don78395dherre
    @Don78395dherre Місяць тому

    Wtf you are already been write the code qnd explaining them , why don't you write the code and explain that during video

  • @carlotadias9335
    @carlotadias9335 2 місяці тому

    hello, I have this config
    import { defineConfig } from "drizzle-kit";
    export default defineConfig({
    schema:"./src/db/schema.ts",
    out: "./src/db/migrations",
    dialect: "sqlite",
    driver: "d1-http",
    strictNullChecks : true,
    strict: true,
    dbCredentials: {
    url: "file:./src/db/sqlite.db",
    },
    });
    And I'm having the error in the url inside of the dbCredentials :
    Object literal may only specify known properties, and 'url' does not exist in type '{ accountId: string; databaseId: string; token: string; }'.ts(2353)
    (property) url: string
    Any idea on what can be wrong ??
    Thank you in advance,