back to home

kysely-org / kysely

A type-safe TypeScript SQL query builder

13,480 stars
382 forks
158 issues
TypeScriptMDXJavaScript

AI Architecture Analysis

This repository is indexed by RepoMind. By analyzing kysely-org/kysely in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.

Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.

Embed this Badge

Showcase RepoMind's analysis directly in your repository's README.

[![Analyzed by RepoMind](https://img.shields.io/badge/Analyzed%20by-RepoMind-4F46E5?style=for-the-badge)](https://repomind-ai.vercel.app/repo/kysely-org/kysely)
Preview:Analyzed by RepoMind

Repository Summary (README)

Preview

Stand With Ukraine

NPM Version Tests License Issues Pull Requests GitHub contributors NPM Downloads JSR Downloads JSR Score

Join the discussion ⠀⠀⠀⠀⠀⠀⠀

Discord Bluesky

Get started

Postgres MySQL MicrosoftSQLServer SQLite & more!

Kysely

Kysely (pronounce “Key-Seh-Lee”) is a type-safe and autocompletion-friendly TypeScript SQL query builder. Inspired by Knex.js. Mainly developed for Node.js but also runs on all other JavaScript environments like Deno, Bun, Cloudflare Workers and web browsers.

Kysely makes sure you only refer to tables and columns that are visible to the part of the query you're writing. The result type only has the selected columns with correct types and aliases. As an added bonus you get autocompletion for all that stuff.

As shown in the gif above, through the pure magic of modern TypeScript, Kysely is even able to parse the alias given to pet.name and add the pet_name column to the result row type. Kysely is able to infer column names, aliases and types from selected subqueries, joined subqueries, with statements and pretty much anything you can think of.

Of course there are cases where things cannot be typed at compile time, and Kysely offers escape hatches for these situations. See the sql template tag and the DynamicModule for more info.

All API documentation is written in the typing files and you can simply hover over the module, class or method you're using to see it in your IDE. The same documentation is also hosted here.

If you start using Kysely and can't find something you'd want to use, please open an issue or join our Discord server.

Getting started

Please visit our documentation site kysely.dev to get started. We also have a comprehensive API documentation hosted here, but you can access the same documentation in your IDE by hovering over a class/method/property/whatever.

Core team

Project leads

Responsible for project direction, API design, maintenance, code reviews, community support, documentation, and working on some of the most impactful/challenging things.

<table> <tbody> <tr> <td align="center"> <a href="https://github.com/koskimas"> <img src="https://avatars.githubusercontent.com/u/846508?v=4?s=100" width="100px;" alt=""/> <br /> Sami Koskimäki </a> <br /> (the <a href="https://web.archive.org/web/20211203210043/https://www.jakso.me/blog/kysely-a-type-safe-sql-query-builder-for-typescript">author</a>) </td> <td align="center"> <a href="https://github.com/igalklebanov"> <img src="https://avatars.githubusercontent.com/u/14938291?v=4&s=100" width="100px;" alt=""/> <br /> Igal Klebanov </a> <br /> (the <a href="https://github.com/kysely-org/kysely/pull/1414#issuecomment-2781281996">dynamo</a>) </td> </tr> </tbody> </table>

Honorable mentions

People who had special impact on the project and its growth.

<table> <tbody> <tr> <td align="center"> <a href="https://github.com/fhur"> <img src="https://avatars.githubusercontent.com/u/6452323?v=4&s=100" width="100px;" alt=""/> <br /> Fernando Hurtado </a> <br /> (1st <a href="https://kysely.dev">docs</a>) </td> <td align="center"> <a href="https://github.com/wirekang"> <img src="https://avatars.githubusercontent.com/u/43294688?v=4&s=100" width="100px;" alt=""/> <br /> Wirekang </a> <br /> (<a href="https://kyse.link">playground</a>) </td> <td align="center"> <a href="https://github.com/tgriesser"> <img src="https://avatars.githubusercontent.com/u/154748?v=4&s=100" width="100px;" alt=""/> <br /> Tim Griesser </a> <br /> (<a href="https://knexjs.org/">Knex</a>) </td> </tr> <tr> <td align="center"> <a href="https://github.com/RobinBlomberg"> <img src="https://avatars.githubusercontent.com/u/20827397?v=4&s=100" width="100px;" alt=""/> <br /> Robin Blomberg </a> <br /> (<a href="https://github.com/RobinBlomberg/kysely-codegen">codegen</a>) </td> <td align="center"> <a href="https://github.com/nexxeln"> <img src="https://avatars.githubusercontent.com/u/95541290?v=4&s=100" width="100px" alt="" /> <br /> Shoubhit Dash </a> <br /> (prisma <a href="https://www.nexxel.dev/blog/typesafe-database">idea</a>) </td> <td align="center"> <a href="https://github.com/nexxeln"> <img src="https://avatars.githubusercontent.com/u/3050355?v=4&s=100" width="100px" alt="" /> <br /> Valtýr Örn Kjartansson </a> <br /> (prisma <a href="https://github.com/valtyr/prisma-kysely">impl</a>) </td> </tr> <tr> <td align="center"> <a href="https://github.com/thdxr"> <img src="https://avatars.githubusercontent.com/u/826656?v=4&s=100" width="100px;" alt=""/> <br /> Dax Raad </a> <br /> (early <a href="https://thdxr.com/post/serverless-relational-showdown">adopter</a>) </td> <td align="center"> <a href="https://github.com/t3dotgg"> <img src="https://avatars.githubusercontent.com/u/6751787?v=4&s=100" width="100px;" alt=""/> <br /> Theo Browne </a> <br /> (early <a href="https://discord.com/channels/966627436387266600/988912020558602331/993220628154961930">promoter</a>) </td> <td align="center"> <a href="https://github.com/leerob"> <img src="https://avatars.githubusercontent.com/u/9113740?v=4&s=100" width="100px;" alt="" /> <br /> Lee Robinson </a> <br /> (early <a href="https://x.com/leerob/status/1576929372811849730">promoter</a>) </td> </tr> <tr> <td align="center"> <a href="https://github.com/ethanresnick"> <img src="https://avatars.githubusercontent.com/u/471894?v=4&s=100" width="100px" alt="" /> <br /> Ethan Resnick </a> <br /> (timely <a href="https://github.com/kysely-org/kysely/issues/494">feedback</a>) </td> <td align="center"> <a href="https://github.com/thetutlage"> <img src="https://avatars.githubusercontent.com/u/1706381?v=4&s=100" width="100px;" alt="" /> <br /> Harminder Virk </a> <br /> (dope <a href="https://github.com/thetutlage/meta/discussions/8">writeup</a>) </td> <td align="center"> <a href="https://github.com/elitan"> <img src="https://avatars.githubusercontent.com/u/331818?v=4&s=100" width="100px;" alt="" /> <br /> Johan Eliasson </a> <br /> (<a href="https://eliasson.me/articles/crafting-the-perfect-t3-stack-my-journey-with-kysely-atlas-and-clerk">promoter</a>/<a href="https://www.youtube.com/watch?v=u2s39dRIpCM">educator</a>) </td> </tr> <!-- <tr> <td align="center"> <a href=""> <img src="" width="100px;" alt="" /> <br /> Name </a> <br /> (contribution) </td> </tr> --> </tbody> </table>

All contributors

<p align="center"> <a href="https://github.com/kysely-org/kysely/graphs/contributors"> <img src="https://contrib.rocks/image?repo=kysely-org/kysely" /> </a> </br> <span>Want to contribute? Check out our <a href="./CONTRIBUTING.md" >contribution guidelines</a>.</span> </p> <p align="center"> <a href="https://vercel.com/?utm_source=kysely&utm_campaign=oss"> <img src="https://kysely.dev/img/powered-by-vercel.svg" alt="Powered by Vercel" /> </a> </p>