mirror of
https://github.com/kunkunsh/kunkun.git
synced 2025-04-04 14:46:42 +00:00

* feat: add drizzle orm * feat: update drizzle configuration and schema management - Added a check for DB_FILE_NAME in drizzle.config.ts to ensure it's set. - Updated package.json to change the package name to @kksh/drizzle and added exports for schema and relations. - Enhanced README.md with instructions for using the schema generation. - Refactored schema.ts for improved readability and organization of imports. * add tauri-plugin-sql * feat: add database select and execute commands - Introduced `select` and `execute` functions in the database module to facilitate querying and executing SQL commands. - Updated the Tauri plugin to expose these commands, allowing for database interactions from the frontend. - Added corresponding permissions for the new commands in the permissions configuration. - Enhanced the database library with JSON value handling for query parameters. * fix: sqlite select command * drizzle ORM verified working * refactor: clean up database module by removing unused SelectQueryResult type and disabling eslint for explicit any usage * pnpm lock update * Update enum definition for type safety - Changed enum to use 'as const' for better type inference - Ensured more robust handling of extension publish sources * reimplemented most db command functions with ORM (migrate from tauri command invoke * fixed searchExtensionData orm function * Refactor ORM commands and searchExtensionData function for improved readability and consistency - Reformatted import statements for better organization. - Cleaned up whitespace and indentation in searchExtensionData function. - Enhanced readability of SQL conditions and query building logic. - Disabled eslint for explicit any usage in the troubleshooters page. * Fix test assertions in database module to use array indexing for results format rust code * update deno lock * move drizzle from desktop to drizzle package * update pnpm version and lock * refactor: migrate db tauri commands to drizzle * refactor: remove unused extension and command CRUD operations from db module
36 lines
831 B
Markdown
36 lines
831 B
Markdown
# drizzle
|
|
|
|
- Only use `pull` to generate the schema from existing database.
|
|
- Don't `migrate` or `push`.
|
|
|
|
```bash
|
|
export DB_FILE_NAME="~/Library/Application Support/sh.kunkun.desktop/kk.dev.sqlite"
|
|
bunx drizzle-kit pull
|
|
```
|
|
|
|
We are using sqlite with fts5, which drizzle doesn't support yet, so pushing the schema will destroy the existing schema.
|
|
|
|
We only use pulled schema to generate sql queries.
|
|
|
|
## Update Schema
|
|
|
|
After `drizzle-kit pull` the schema may have problem with JSON type and boolean type.
|
|
|
|
Will need to manually update the following
|
|
|
|
### JSON
|
|
|
|
```diff lang="ts"
|
|
+ data: text({ mode: "json" }).notNull(),
|
|
+ metadata: text({ mode: "json" }),
|
|
- data: numeric().notNull(),
|
|
- metadata: numeric(),
|
|
```
|
|
|
|
### Boolean
|
|
|
|
```diff lang="ts"
|
|
+ enabled: integer({ mode: "boolean" }),
|
|
- enabled: numeric().default(sql`(TRUE)`),
|
|
```
|