Home / File/ pgSchema.ts — drizzle-orm Source File

pgSchema.ts — drizzle-orm Source File

Architecture documentation for pgSchema.ts, a typescript file in the drizzle-orm codebase. 1 imports, 1 dependents.

File typescript DrizzleORM 1 imports 1 dependents

Entity Profile

Dependency Diagram

graph LR
  409815ce_f25c_e74f_cb87_6d7e622ce2e3["pgSchema.ts"]
  53497908_16e7_977d_e97d_7414884a88a6["pg-core"]
  409815ce_f25c_e74f_cb87_6d7e622ce2e3 --> 53497908_16e7_977d_e97d_7414884a88a6
  14367cdd_f407_2537_46e8_5358f6eedc9d["pgTest.ts"]
  14367cdd_f407_2537_46e8_5358f6eedc9d --> 409815ce_f25c_e74f_cb87_6d7e622ce2e3
  style 409815ce_f25c_e74f_cb87_6d7e622ce2e3 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import type { AnyPgColumn } from 'drizzle-orm/pg-core';
import { integer, numeric, pgSchema, text, timestamp, varchar } from 'drizzle-orm/pg-core';

export const schema = pgSchema('seeder_lib_pg');

export const customers = schema.table('customer', {
	id: varchar('id', { length: 256 }).primaryKey(),
	companyName: text('company_name').notNull(),
	contactName: text('contact_name').notNull(),
	contactTitle: text('contact_title').notNull(),
	address: text('address').notNull(),
	city: text('city').notNull(),
	postalCode: text('postal_code'),
	region: text('region'),
	country: text('country').notNull(),
	phone: text('phone').notNull(),
	fax: text('fax'),
});

export const employees = schema.table('employee', {
	id: integer('id').primaryKey(),
	lastName: text('last_name').notNull(),
	firstName: text('first_name'),
	title: text('title').notNull(),
	titleOfCourtesy: text('title_of_courtesy').notNull(),
	birthDate: timestamp('birth_date').notNull(),
	hireDate: timestamp('hire_date').notNull(),
	address: text('address').notNull(),
	city: text('city').notNull(),
	postalCode: text('postal_code').notNull(),
	country: text('country').notNull(),
	homePhone: text('home_phone').notNull(),
	extension: integer('extension').notNull(),
	notes: text('notes').notNull(),
	reportsTo: integer('reports_to').references((): AnyPgColumn => employees.id),
	photoPath: text('photo_path'),
});

export const orders = schema.table('order', {
	id: integer('id').primaryKey(),
	orderDate: timestamp('order_date').notNull(),
	requiredDate: timestamp('required_date').notNull(),
	shippedDate: timestamp('shipped_date'),
	shipVia: integer('ship_via').notNull(),
	freight: numeric('freight').notNull(),
	shipName: text('ship_name').notNull(),
	shipCity: text('ship_city').notNull(),
	shipRegion: text('ship_region'),
	shipPostalCode: text('ship_postal_code'),
	shipCountry: text('ship_country').notNull(),

	customerId: text('customer_id')
		.notNull()
		.references(() => customers.id, { onDelete: 'cascade' }),

	employeeId: integer('employee_id')
		.notNull()
		.references(() => employees.id, { onDelete: 'cascade' }),
});

export const suppliers = schema.table(
	'supplier',
	{
		id: integer('id').primaryKey(),
		companyName: text('company_name').notNull(),
		contactName: text('contact_name').notNull(),
		contactTitle: text('contact_title').notNull(),
		address: text('address').notNull(),
		city: text('city').notNull(),
		region: text('region'),
		postalCode: text('postal_code').notNull(),
		country: text('country').notNull(),
		phone: text('phone').notNull(),
	},
);

export const products = schema.table('product', {
	id: integer('id').primaryKey(),
	name: text('name').notNull(),
	quantityPerUnit: text('quantity_per_unit').notNull(),
	unitPrice: numeric('unit_price').notNull(),
	unitsInStock: integer('units_in_stock').notNull(),
	unitsOnOrder: integer('units_on_order').notNull(),
	reorderLevel: integer('reorder_level').notNull(),
	discontinued: integer('discontinued').notNull(),

	supplierId: integer('supplier_id')
		.notNull()
		.references(() => suppliers.id, { onDelete: 'cascade' }),
});

export const details = schema.table('order_detail', {
	unitPrice: numeric('unit_price').notNull(),
	quantity: integer('quantity').notNull(),
	discount: numeric('discount').notNull(),

	orderId: integer('order_id')
		.notNull()
		.references(() => orders.id, { onDelete: 'cascade' }),

	productId: integer('product_id')
		.notNull()
		.references(() => products.id, { onDelete: 'cascade' }),
});

Domain

Dependencies

  • pg-core

Frequently Asked Questions

What does pgSchema.ts do?
pgSchema.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain.
What does pgSchema.ts depend on?
pgSchema.ts imports 1 module(s): pg-core.
What files import pgSchema.ts?
pgSchema.ts is imported by 1 file(s): pgTest.ts.
Where is pgSchema.ts in the architecture?
pgSchema.ts is located at drizzle-seed/tests/northwind/pgSchema.ts (domain: DrizzleORM, directory: drizzle-seed/tests/northwind).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free