Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/beenotung/gen-sql-type
Generate Typescript Types from raw SQL statements
https://github.com/beenotung/gen-sql-type
code-generation gen-type sql type-gen typescript
Last synced: 15 days ago
JSON representation
Generate Typescript Types from raw SQL statements
- Host: GitHub
- URL: https://github.com/beenotung/gen-sql-type
- Owner: beenotung
- License: bsd-2-clause
- Created: 2021-02-19T18:35:11.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-10-03T05:07:25.000Z (4 months ago)
- Last Synced: 2024-12-25T13:09:23.514Z (22 days ago)
- Topics: code-generation, gen-type, sql, type-gen, typescript
- Language: TypeScript
- Homepage: https://gen-sql-type.surge.sh
- Size: 87.9 KB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# gen-sql-type
Generate Typescript Types from raw SQL statements
[![npm Package Version](https://img.shields.io/npm/v/gen-sql-type)](https://www.npmjs.com/package/gen-sql-type)
Playground: https://gen-sql-type.surge.sh/
## How it works
This library scan the plain sql statements then auto generate Typescript types of the result row and named parameters.
(Also supports prepared statement)## Features
- [x] Extract types from sql statement
- [x] Support alias column name
- [x] Support function call (e.g. `COUNT(*)`)
- [x] Support quoted column name with escape sequence (e.g. treat `'can''t'` as `"can't"`)
- [x] Support named parameters (e.g. `:id` and `@username`)
- [x] Supported statement types:
- `SELECT`
- `UPDATE`
- `DELETE`
- `INSERT`
- [x] Support select from `WITH`-clause
- [x] Generate Typescript type for:
- [x] Row of select result
- [x] Named parameters for prepared statement
- [x] Isomorphic, support both node.js and browser## Usage Example
Given _user-service.ts_:
```typescript
const sqlTypeFile = SqlTypeFile.withPrefix(__filename)export class UserService {
async login(parameters: LoginUserParameters): Promise {
const sql: string = sqlTypeFile.wrapSql(
'LoginUser',
'select password_hash from user where id = :id',
)
return mockExec(sql, parameters)[0]
}async logout(parameters: LogoutUserParameters) {
const sql: string = sqlTypeFile.wrapSql(
'LogoutUser',
'update session set active = false where token = :token',
)
return mockExec(sql, parameters)
}
}
```Upon execution, it will auto generate _user-service.types.ts_:
```typescript
export type LoginUserParameters = {
id: any
}
export type LoginUserRow = {
password_hash: any
}export type LogoutUserParameters = {
token: any
}
```Complete example refers to [./examples/user-service.ts](./examples/user-service.ts)
## License
This is free and open-source software (FOSS) with
[BSD-2-Clause License](./LICENSE)