TypeORM - Thực thể
Thực thể là một tập hợp các trường và các hoạt động cơ sở dữ liệu liên quan. Nó được sử dụng để ánh xạ bảng cơ sở dữ liệu và các trường của nó với các thực thể và thuộc tính của nó. Chương này giải thích chi tiết về các thực thể TypeORM.
Giới thiệu
Hãy để chúng tôi tạo một lớp Thực thể đơn giản trong mã của chúng tôi. Di chuyển đến vị trí gốc dự án của bạn và vào bên trong thư mục src và chuyển đến thư mục thực thể. Bây giờ, hãy tạo tệp TypeScript, Student.ts và nhập mã bên dưới -
Student.ts
import {Entity, PrimaryGeneratedColumn, Column} from "typeorm";
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: number;
@Column()
Name: string;
@Column()
age: number;
}
Đây,
- Entity() lớp decorator được sử dụng để biểu thị rằng Student lớp là một thực thể.
- PrimaryGeneratedColumn() lớp decorator được sử dụng để biểu thị rằng cột id là cột khóa chính của Student thực thể.
- Column() lớp decorator được sử dụng để đại diện cho các cột khác như Name và Age sau đó Student thực thể.
Bây giờ, lớp Thực thể Studentđược tạo ra. TypeORM sẽ tự động tạo một bảng tương ứng vớiStudent thực thể trong cơ sở dữ liệu của chúng tôi và nó sẽ được đặt tên là student. Bây giờ, chuyển sangsrc/index.ts tệp và thêm mã sau:
index.ts
import "reflect-metadata";
import {createConnection} from "typeorm";
import {Student} from "./entity/Student"; //import Student entity
createConnection().then(async connection => {
console.log("Inserting a new record into the student database...");
//create student object const stud = new Student();
//Assign student name and age here stud.Name = "student1";
stud.age = 12;
//save student object in connection await connection.manager.save(stud); console.log("Saved a new user with id: " + stud.id);
console.log("Loading users from the database...");
//Display student saved records const students = await connection.manager.find(Student); console.log("Loaded users: ", students);
console.log("Here you can setup and run express/koa/any other framework.");
}).catch(error => console.log(error));
Đây,
- Dòng 1 - 3 nhập các lớp có liên quan, createConnection và Student
- Dòng 5 tạo một kết nối mới đến cơ sở dữ liệu bằng cách sử dụng createConnection và nếu kết nối được thiết lập, nó sẽ thực thi mã bên trong then khối.
- Dòng 10 tạo đối tượng Student mới, stud.
- Dòng 13-14 đặt các thuộc tính của đối tượng stud mới tạo của chúng ta.
- Dòng 17 lưu thực thể vào cơ sở dữ liệu bằng cách sử dụng phương thức lưu có sẵn trong connection.manager vật.
- Dòng 23 tìm nạp thông tin chi tiết về sinh viên từ cơ sở dữ liệu bằng cách sử dụng phương pháp tìm có sẵn trong connection.manager vật.
Khởi động máy chủ Mysql và chạy ứng dụng của bạn
Chúng tôi đã tạo thực thể Sinh viên và tạo kết nối trong index.ts. Hãy để chúng tôi khởi động cả máy chủ MySql và ứng dụng của bạn.
npm start
Thao tác này sẽ trả về kết quả sau trên màn hình của bạn:
Đầu ra
Mở mysql máy chủ theo dõi student bảng được thêm vào bên trong cơ sở dữ liệu của bạn.
Cột
Như đã học trước đó, Thực thể thực sự là một tập hợp các thuộc tính. Như đối tượng thực thể tham chiếu đến bảng cơ sở dữ liệu. Các thuộc tính / biến thành viên của nó tham chiếu đến các trường / cột của bảng cơ sở dữ liệu tương ứng. TypeORM hỗ trợ tất cả các loại trường cơ sở dữ liệu thông qua lớp Column. Hãy để chúng tôi tìm hiểu các loại cột khác nhau được hỗ trợ bởi TypeORM trong chương này.
@Column() lớp decorator được sử dụng để đại diện cho cột và kiểu của nó trong thực thể.
Ví dụ: thuộc tính tuổi của thực thể sinh viên và loại thuộc tính tuổi có thể được xác định như sau:
@Column("int") age: integer; // OR @Column({ type: "int" }) age: integer;
Đây,
- agelà thuộc tính của thực thể. Nói cách khác, tuổi là một trường / cột trong bảng sinh viên trong cơ sở dữ liệu.
- int đại diện cho kiểu của cột tuổi trong cơ sở dữ liệu.
TypeORM hỗ trợ gần như tất cả các kiểu có sẵn trong cơ sở dữ liệu phổ biến. Trên thực tế, TypeORM cho phép đặt các kiểu khác nhau cho mỗi công cụ cơ sở dữ liệu. Chúng tôi có thể sử dụng bất kỳ loại cơ sở dữ liệu nào được hỗ trợ bởi công cụ cơ sở dữ liệu của chúng tôi mà không gặp bất kỳ vấn đề gì.
Ví dụ, kiểu được hỗ trợ bởi TypeORM cho công cụ cơ sở dữ liệu postgresql như sau:
int, int2, int4, int8, smallint, integer, bigint, decimal, numeric, real, float, float4, float8, double precision, money, character varying,
varchar, character, char, text, citext, hstore, bytea, bit, varbit, bit
varying, timetz, timestamptz, timestamp, timestamp without time zone, timestamp with time zone, date, time, time without time zone, time with time zone, interval, bool, boolean, enum, point, line, lseg, box, path, polygon, circle, cidr, inet, macaddr, tsvector, tsquery, uuid, xml, json, jsonb, int4range, int8range, numrange, tsrange, tstzrange, daterange, geometry, geography, cube
Tương tự, TypeORM hỗ trợ một tập hợp các kiểu dữ liệu khác nhau cho MySQL.
Tùy chọn cột
TypeORM cung cấp một loạt các tùy chọn khác với loại để mô tả cột. Ví dụ: tùy chọn độ dài đề cập đến độ dài của trường cơ sở dữ liệu và nó có thể được chỉ định như sau:
@Column("varchar", { length: 100 })
Một số tùy chọn cột phổ biến nhất như sau:
- name - Tên của trường / cột cơ sở dữ liệu.
- length - Độ dài của trường / cột cơ sở dữ liệu.
- nullable - Chỉ định trường / cột cơ sở dữ liệu có cho phép null hay không.
- default - Giá trị mặc định của trường / cột cơ sở dữ liệu.
- primary - Chỉ định trường / cột cơ sở dữ liệu có phải là khóa chính của bảng hay không.
- unique - Chỉ định xem trường / cột cơ sở dữ liệu là duy nhất
- *precision** - Độ chính xác của trường / cột cơ sở dữ liệu
- scale - Quy mô của trường / cột cơ sở dữ liệu
- comment - Nhận xét hoặc mô tả về trường / cột cơ sở dữ liệu
@Generated decorator
TypeORM cung cấp trình trang trí bổ sung, @Generated để tự động tạo các giá trị cột. Ví dụ: Mã định danh duy nhất phổ biến (UUID) khá phổ biến được sử dụng trong cơ sở dữ liệu để lưu trữ giá trị duy nhất trong một cột. Mã mẫu để tạo UUID như sau:
@Entity()
export class Student {
@PrimaryColumn()
id: number;
@Column()
@Generated("uuid")
uuid: string;
}
Đây,
uuid được tạo tự động và được lưu trữ bên trong cơ sở dữ liệu.
Cột chính
Ít nhất một trường cột chính là bắt buộc đối với bất kỳ thực thể nào trong cơ sở dữ liệu. Nó được phân thành các loại trang trí khác nhau. Chúng ta sẽ thảo luận về nó từng cái một.
@PrimaryColumn()
Trình trang trí @PrimaryColumn () được sử dụng để tạo cột chính cho bất kỳ loại dữ liệu nào. Ví dụ đơn giản được hiển thị bên dưới,
import {Entity, PrimaryColumn} from "typeorm";
@Entity()
export class Student {
@PrimaryColumn()
id: number;
}
Đây,
id là một số nguyên, không chấp nhận các giá trị trùng lặp, nhưng chúng ta cần gán các giá trị.
Chúng tôi cũng có thể chỉ định cột chính cho một hoặc nhiều trường, nếu tình huống yêu cầu.
Thí dụ
import {Entity, PrimaryColumn} from "typeorm";
@Entity()
export class Student {
@PrimaryColumn()
id: number;
@PrimaryColumn()
email: string;
@PrimaryColumn()
phone: number;
}
@PrimaryGeneratedColumn ()
@PrimaryGeneratedColumn()được sử dụng để chỉ định cột chính cũng như tự động tạo giá trị cột trong cơ sở dữ liệu. Nó được hiển thị bên dưới -
import {Entity, PrimaryGeneratedColumn} from "typeorm";
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: number;
}
Đây,
Bạn không phải gán giá trị id; nó sẽ được tạo tự động bởi TypeORM trong bảng cơ sở dữ liệu.
@PrimaryGeneratedColumn (“uuid”)
@PrimaryGeneratedColumn cũng chấp nhận một đối số để chỉ định loại trình tạo. Một trong những cách sử dụng chính là tạo id duy nhất dựa trên UUID.
import {Entity, PrimaryGeneratedColumn} from "typeorm";
@Entity()
export class Student {
@PrimaryGeneratedColumn("uuid") id: string;
}
kiểu cột đơn giản
Cơ sở dữ liệu quan hệ nâng cao hỗ trợ kiểu dữ liệu mảng. Để hỗ trợ kiểu dữ liệu mảng, TypeORM cung cấp một kiểu cột đặc biệt, * mảng đơn giản "để lưu trữ các giá trị mảng nguyên thủy. Mã mẫu để sử dụng như sau:
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: number;
@Column("simple-array")
names: string[];
}
loại cột đơn giản json
Rất nhiều công cụ cơ sở dữ liệu hiện đại hỗ trợ cơ sở dữ liệu JSON. Để sử dụng kiểu dữ liệu JSON, TypeORM cung cấp một kiểu đặc biệt, json đơn. Mã mẫu để sử dụng nó như sau:
@Entity()
export class Student {
@PrimaryGeneratedColumn()
id: number;
@Column("simple-json")
info: { firstName: string, middleName: string, lastName: string };
}
Giá trị này có thể được xác định trong index.ts là,
index.ts
const stud = new Student();
stud.info = { firstName: "John", middleName: "peter", lastName: "Michael" };
Cột đặc biệt
TypeORM hỗ trợ các cột đặc biệt sau
- @CreateDateColumn - Đây là một cột đặc biệt để tự động đặt ngày chèn của thực thể.
- @UpdateDateColumn - Nó được sử dụng để đặt thời gian cập nhật của thực thể tự động.
- @VersionColumn - Đặt số phiên bản cho thực thể tự động.
Thực thể kế thừa
Kế thừa thực thể được sử dụng để giảm sự trùng lặp của các thực thể. Hãy xem xét các thực thể dưới đây -
Result.ts
@Entity()
export class Result {
@PrimaryGeneratedColumn()
id: number;
@Column()
title: string;
@Column()
description: string;
@Column()
eligible: string
}
Điểm.
Mã cho grade.ts như sau:
@Entity()
export class Grade {
@PrimaryGeneratedColumn()
id: number;
@Column()
name: string;
@Column()
title: string;
@Column()
description: string;
@Column()
grading : string;
}
Đây,
Hai thực thể trên có id cột, tiêu đề và mô tả. Sử dụng kế thừa thực thể, chúng tôi tạo một Chi tiết lớp cơ sở và kết hợp hai thực thể trên như được chỉ định bên dưới.
Thông tin chi tiết.
export abstract class Details {
@PrimaryGeneratedColumn()
id: number;
@Column()
title: string;
@Column()
description: string;
}
@Entity()
export class Result extends Details{
@Column()
eligible: string
}
@Entity()
export class Grade extends Details{
@Column()
name : string;
@Column()
grading : string;
}
Bây giờ khởi động máy chủ của bạn, bạn có thể thấy phản hồi bên dưới,
Bây giờ hãy mở máy chủ mysql của bạn và di chuyển đến cơ sở dữ liệu của bạn, bạn có thể thấy các bảng sau,