CREATE TABLE "department" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "hospital" uuid NOT NULL, "description" varchar, "isActive" boolean DEFAULT true NOT NULL, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "doctor" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "username" varchar NOT NULL, "password" varchar NOT NULL, "phone" varchar NOT NULL, "hospitalId" uuid NOT NULL, "departmentId" uuid, "groupId" uuid, "roleId" uuid NOT NULL, "isDoctor" boolean DEFAULT true NOT NULL, "isActive" boolean DEFAULT true NOT NULL, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL, CONSTRAINT "doctor_username_unique" UNIQUE("username") ); --> statement-breakpoint CREATE TABLE "group" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "departmentId" uuid NOT NULL, "description" varchar, "isActive" boolean DEFAULT true NOT NULL, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "hospital" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "description" text, "isActive" boolean DEFAULT true NOT NULL, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "patient" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "chiefDoctorId" uuid NOT NULL, "sharedWith" text, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "role" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" varchar NOT NULL, "code" varchar NOT NULL, "description" text, "permissions" text, "isActive" boolean DEFAULT true NOT NULL, "createdAt" timestamp DEFAULT now() NOT NULL, "updatedAt" timestamp DEFAULT now() NOT NULL, CONSTRAINT "role_name_unique" UNIQUE("name"), CONSTRAINT "role_code_unique" UNIQUE("code") );