mirror of https://github.com/usememos/memos
chore: update dev version (#489)
parent
a2831b37c4
commit
a4a5e539ed
@ -0,0 +1,5 @@
|
|||||||
|
-- migration_history
|
||||||
|
CREATE TABLE IF NOT EXISTS migration_history (
|
||||||
|
version TEXT NOT NULL PRIMARY KEY,
|
||||||
|
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now'))
|
||||||
|
);
|
@ -0,0 +1,11 @@
|
|||||||
|
-- memo_relation
|
||||||
|
CREATE TABLE memo_relation (
|
||||||
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
|
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
|
||||||
|
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
|
||||||
|
memo_id INTEGER NOT NULL,
|
||||||
|
related_memo_id INTEGER NOT NULL,
|
||||||
|
type TEXT NOT NULL,
|
||||||
|
description TEXT NOT NULL DEFAULT '',
|
||||||
|
UNIQUE(memo_id, related_memo_id, type)
|
||||||
|
);
|
@ -1,65 +0,0 @@
|
|||||||
package db
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"database/sql"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Table struct {
|
|
||||||
Name string
|
|
||||||
SQL string
|
|
||||||
}
|
|
||||||
|
|
||||||
//lint:ignore U1000 Ignore unused function temporarily for debugging
|
|
||||||
//nolint:all
|
|
||||||
func findTable(ctx context.Context, tx *sql.Tx, tableName string) (*Table, error) {
|
|
||||||
where, args := []string{"1 = 1"}, []interface{}{}
|
|
||||||
|
|
||||||
where, args = append(where, "type = ?"), append(args, "table")
|
|
||||||
where, args = append(where, "name = ?"), append(args, tableName)
|
|
||||||
|
|
||||||
query := `
|
|
||||||
SELECT
|
|
||||||
tbl_name,
|
|
||||||
sql
|
|
||||||
FROM sqlite_schema
|
|
||||||
WHERE ` + strings.Join(where, " AND ")
|
|
||||||
rows, err := tx.QueryContext(ctx, query, args...)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer rows.Close()
|
|
||||||
|
|
||||||
tableList := make([]*Table, 0)
|
|
||||||
for rows.Next() {
|
|
||||||
var table Table
|
|
||||||
if err := rows.Scan(
|
|
||||||
&table.Name,
|
|
||||||
&table.SQL,
|
|
||||||
); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
tableList = append(tableList, &table)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := rows.Err(); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(tableList) == 0 {
|
|
||||||
return nil, nil
|
|
||||||
} else {
|
|
||||||
return tableList[0], nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func createTable(ctx context.Context, tx *sql.Tx, stmt string) error {
|
|
||||||
_, err := tx.ExecContext(ctx, stmt)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
Loading…
Reference in New Issue