mirror of
https://github.com/hex248/sprint.git
synced 2026-02-08 02:33:01 +00:00
Issue table
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
import { integer, pgTable, varchar } from "drizzle-orm/pg-core";
|
import { integer, pgTable, uniqueIndex, varchar } from "drizzle-orm/pg-core";
|
||||||
|
|
||||||
export const User = pgTable("User", {
|
export const User = pgTable("User", {
|
||||||
id: integer().primaryKey().generatedAlwaysAsIdentity(),
|
id: integer().primaryKey().generatedAlwaysAsIdentity(),
|
||||||
@@ -14,3 +14,23 @@ export const Project = pgTable("Project", {
|
|||||||
.notNull()
|
.notNull()
|
||||||
.references(() => User.id),
|
.references(() => User.id),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
export const Issue = pgTable(
|
||||||
|
"Issue",
|
||||||
|
{
|
||||||
|
id: integer().primaryKey().generatedAlwaysAsIdentity(),
|
||||||
|
projectId: integer()
|
||||||
|
.notNull()
|
||||||
|
.references(() => Project.id),
|
||||||
|
|
||||||
|
number: integer("number").notNull(),
|
||||||
|
|
||||||
|
title: varchar({ length: 256 }).notNull(),
|
||||||
|
description: varchar({ length: 2048 }).notNull(),
|
||||||
|
},
|
||||||
|
(t) => [
|
||||||
|
// ensures unique numbers per project
|
||||||
|
// you can have Issue 1 in PROJ and Issue 1 in TEST, but not two Issue 1s in PROJ
|
||||||
|
uniqueIndex("unique_project_issue_number").on(t.projectId, t.number),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user