टाइप करें - त्वरित गाइड

टाइप फ्रेमवर्क एक है Object Relational Mapping (ORM)ढांचा। सामान्य रूप में,Object भाग आपके आवेदन में डोमेन / मॉडल को संदर्भित करता है, Relational भाग संबंधपरक डेटाबेस प्रबंधन प्रणाली (जैसे Oracle, MySQL, MS-SQL, PostgreSQL, आदि) और अंत में तालिकाओं के बीच संबंध को संदर्भित करता है। Mapping भाग मॉडल और हमारे तालिकाओं को पाटने के कार्य को संदर्भित करता है।

ORM एक प्रकार का टूल है जो डेटाबेस टेबल के साथ संस्थाओं को मैप करता है। ओआरएम ऑब्जेक्ट-टू-टेबल और टेबल-टू-ऑब्जेक्ट रूपांतरण को स्वचालित करके सरल विकास प्रक्रिया प्रदान करता है। एक बार जब आप अपने डेटा मॉडल को एक जगह लिख सकते हैं, तो कोड को अपडेट, रखरखाव और पुन: उपयोग करना आसान हो जाता है।

चूंकि, मॉडल कमजोर रूप से शेष एप्लिकेशन के लिए बाध्य है, आप इसे आवेदन के अन्य भाग के साथ किसी भी कठिन निर्भरता के बिना बदल सकते हैं और आसानी से आवेदन के अंदर कहीं भी इसका उपयोग कर सकते हैं। टाइपऑफ बहुत ही लचीला है, डीबी सिस्टम को एप्लिकेशन से दूर कर देता है और हमें OOPS अवधारणा के उपयोग से लाभ देता है।

अवलोकन

टाइपफॉर्म एक ऑब्जेक्ट रिलेशनल मैपर लाइब्रेरी है जो नोड.जेएस में चल रही है और टाइपस्क्रिप्ट में लिखी गई है। टाइपस्क्रिप्ट वैकल्पिक टाइपिंग के साथ जावास्क्रिप्ट में सुधार है। टाइपस्क्रिप्ट एक संकलित भाषा है। रन-टाइम पर इसकी व्याख्या नहीं की जाती है। टाइपस्क्रिप्ट कंपाइलर टाइपस्क्रिप्ट फाइलें (.ts) लेता है और उन्हें जावास्क्रिप्ट फाइलों (.js) में संकलित करता है।

टाइप MySQL, PostgreSQL, MariaDB, SQLite, MS SQL Server, Oracle, SAP हाना और WebSQL जैसे कई डेटाबेस का समर्थन करता है। टाइप करें डेटाबेस से जुड़ने वाले नए ऐप्स को मचान करने के लिए एक आसान-से-उपयोग ओआरएम है। टाइप कार्यक्षमता कार्यक्षमता RDBMS- विशिष्ट अवधारणाएँ हैं।

हम जल्दी से नई परियोजनाओं और सूक्ष्म सेवाओं का निर्माण कर सकते हैं। यह अन्य प्रोग्रामिंग भाषाओं से समान उपकरण जैसे हाइबरनेट, डॉक्ट्रिन, एंटिटी फ्रेमवर्क, आदि से प्रेरित है।

टाइप की विशेषताएं

टाइप निम्नलिखित विशेषताओं के साथ आता है -

  • अपने मॉडल के आधार पर स्वचालित रूप से डेटाबेस तालिका योजनाएं बनाएं।
  • आसानी से डेटाबेस में ऑब्जेक्ट डालें, अपडेट करें और हटाएं।
  • तालिकाओं के बीच मैपिंग (एक-से-एक, एक-से-एक और कई-से-कई) बनाएं।
  • सरल सीएलआई कमांड प्रदान करता है।

टाइप के लाभ

ORM फ्रेमवर्क को सरल कोडिंग के साथ टाइप करना आसान है। इसके निम्नलिखित लाभ हैं -

  • उच्च गुणवत्ता और शिथिल-युग्मित अनुप्रयोग।
  • स्केलेबल एप्लिकेशन।
  • आसानी से अन्य मॉड्यूल के साथ एकीकृत।
  • छोटे से लेकर एंटरप्राइज ऐप्स तक किसी भी आर्किटेक्चर को पूरी तरह से फिट करता है।

यह अध्याय आपके मशीन पर टाइप करने के तरीके को स्थापित करने के बारे में बताता है। स्थापना पर जाने से पहले, कृपया सुनिश्चित करें कि npm स्थापित है। यह सुनिश्चित करने के लिए कि आपके पास npm है, आप अपने टर्मिनल में निम्न कमांड चला सकते हैं।

npm -v

यह संस्करण दिखाता है। यदि यह स्थापित नहीं है, तो नवीनतम संस्करण डाउनलोड करें और अपनी मशीन पर स्थापित करें।

टाइप करें स्थापित करें

Npm मॉड्यूल का उपयोग करके स्थानीय रूप से टाइप करें

npm install typeorm --save

उपरोक्त कमांड निष्पादित करने के बाद, आपको नीचे दी गई प्रतिक्रिया मिलेगी -

+ [email protected] 
+ 
added 1 package and audited 1236 packages in 4.729s

वैकल्पिक रूप से, टाइप करें विश्व स्तर पर स्थापित करने के लिए, नीचे दिए गए कमांड का उपयोग करें -

npm install typeorm -g

उसके बाद, npm का उपयोग करके वैकल्पिक पैकेज रिफ्लेक्ट-मेटाडाटा स्थापित करें -

npm install reflect-metadata --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1236 packages in 2.426s

अब, एक और वैकल्पिक पैकेज स्थापित करें। नीचे दिए गए आदेश का उपयोग कर नोड टाइपिंग -

npm install @types/node --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ @types/[email protected] 

added 1 package and audited 1236 packages in 2.167s

डेटाबेस ड्राइवर स्थापित करें

इस खंड में, हम अपने डेटाबेस के लिए आवश्यक नोड पैकेज स्थापित करते हैं।

स्थापित करने के लिए MySQL या MariaDB पैकेज, नीचे कमांड का उपयोग करें -

npm install mysql --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1236 packages in 4.36s

स्थापित करने के लिए PostgreSQL पैकेज, नीचे कमांड का उपयोग करें -

npm install pg --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1236 packages in 2.863s

स्थापित करने के लिए SQLite पैकेज, नीचे कमांड का उपयोग करें -

npm install sqlite3 --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 
added 48 packages from 45 contributors and audited 1396 packages in 7.31s

स्थापित करने के लिए Microsoft SQL Server पैकेज, नीचे कमांड का उपयोग करें -

npm install mssql --save

आपकी स्क्रीन इस तरह दिखाई देती है,

+ [email protected] 

added 1 package and audited 1655 packages in 2.378s

स्थापित करने के लिए sql.js पैकेज, नीचे कमांड का उपयोग करें -

npm install sql.js --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1655 packages in 6.462s

स्थापित करने के लिए Oracle server पैकेज, नीचे कमांड का उपयोग करें -

npm install oracledb --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1655 packages in 2.265s

स्थापित करने के लिए mongodb पैकेज, नीचे कमांड का उपयोग करें -

npm install mongodb --save

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

+ [email protected] 

added 1 package and audited 1655 packages in 3.716s

यह चैप्टर सरल टाइपफॉर्म एप्लिकेशन बनाने के बारे में बताता है। आइए हम 'टाइपफॉर्म' नाम की एक नई निर्देशिका बनाएं और निर्देशिका में जाएं।

cd /path/to/TypeORM/

वाक्य - विन्यास

नई परियोजना बनाने के लिए कमांड का प्रयोग करें -

typeorm init --name <project-name> --database <database-name>

उदाहरण

typeorm init --name FirstProject --database mysql

यहाँ,

FirstProject आपका प्रोजेक्ट नाम है और sqlite3डेटाबेस का नाम है। उपरोक्त कमांड निष्पादित करने के बाद, आप निम्नलिखित प्रतिक्रिया देख सकते हैं,

Project created inside /path/to/TypeORM/FirstProject directory

अब, हमारी परियोजना निर्देशिका में जाएँ और परियोजना निर्भरता का उपयोग करके स्थापित करें npm मापांक,

$ cd FirstProject $ npm install

परियोजना की संरचना

आइए हम अपनी नई बनाई गई परियोजना की परियोजना संरचना को समझते हैं, FirstProject

FirstProject 
├──> src 
│ ├──> entity 
│ │ └──> User.ts 
│ ├──> migration 
│ └──> index.ts 
├──> node_modules 
├──> ormconfig.json 
├──> package.json 
├──> package-lock.json 
└──> tsconfig.json

यहाँ,

  • src - में अपने आवेदन के स्रोत कोड शामिल हैं TypeScriptभाषा: हिन्दी। इसकी एक फाइल हैindex.ts और दो उप निर्देशिकाएं entity तथा migration
  • index.ts - आवेदन के लिए आपका प्रवेश बिंदु।
  • entity - डेटाबेस मॉडल शामिल हैं।
  • migration - डेटाबेस माइग्रेशन कोड होता है।
  • node_modules - स्थानीय रूप से सहेजे गए एनपीएम मॉड्यूल।
  • ormconfig.json- आपके आवेदन की मुख्य विन्यास फाइल। इसमें डेटाबेस कॉन्फ़िगरेशन विवरण और इकाइयां कॉन्फ़िगरेशन शामिल हैं।
  • package.json - नोड मॉड्यूल निर्भरता शामिल हैं।
  • package-lock.json - ऑटो उत्पन्न फ़ाइल और से संबंधित package.json
  • tsconfig.json - टाइपस्क्रिप्ट विशिष्ट संकलक विकल्प शामिल हैं।

ormconfig.json फ़ाइल

आइए हम अपने आवेदन के लिए उपलब्ध कॉन्फ़िगरेशन विकल्प की जांच करें। Ormconfig.json फ़ाइल खोलें और यह इस तरह दिखता है -

{ 
   "type": "mysql", 
   "host": "localhost", 
   "port": 3306, 
   "username": "test", 
   "password": "test", 
   "database": "test", 
   "synchronize": true, 
   "logging": false, 
   "entities": [ 
      "src/entity/**/*.ts" ], 
   "migrations": [ "src/migration/**/*.ts" 
   ], 
   "subscribers": [ "src/subscriber/**/*.ts" 
   ], 
   "cli": { 
      "entitiesDir":"src/entity", "migrationsDir":"src/migration", "subscribersDir":"src/subscriber
   }    
 }

यहाँ,

type, host, username, password, database और पोर्ट विकल्प डेटाबेस सेटिंग से संबंधित हैं। mysql नीचे कॉन्फ़िगरेशन का उपयोग करके कॉन्फ़िगर किया जा सकता है -

{ 
   "type": "mysql", 
   "host": "localhost", 
   "port": 3306, 
   "username": "db_username", "password": "db_password", "database": "db_name" 
}
  • entities - आपकी इकाई कक्षाओं का स्थान संदर्भित करता है।
  • migrations - आपके प्रवासन वर्गों के स्थान को संदर्भित करता है।
  • subscribers - आपके ग्राहक वर्गों के स्थान को संदर्भित करता है।
  • cli - द्वारा उपयोग किए गए विकल्प को संदर्भित करता है TypeORM CLI स्वत: कोड उत्पन्न करने के लिए

MySql सर्वर प्रारंभ करें

आवेदन शुरू करने से पहले, अपनी शुरुआत करें MySQL सर्वर या आपके द्वारा उपयोग किया जाने वाला कोई डेटाबेस सर्वर और सुनिश्चित करें कि यह ठीक से चल रहा है।

अनुप्रयोग चलाएँ

एक बार सब कुछ कॉन्फ़िगर हो जाने पर, हम नीचे दिए गए कमांड का उपयोग करके एप्लिकेशन को निष्पादित कर सकते हैं -

npm start

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

> [email protected] start /Users/../../TypeORM/FirstProject 

> ts-node src/index.ts 

Inserting a new user into the database... Saved a new user with id: 1 Loading users from the database... Loaded users: [ User { id: 1, firstName: 'Timber', lastName: 'Saw', age: 25 }] 

Here you can setup and run express/koa/any other framework.

एप्लिकेशन ने डेटाबेस में एक नया उपयोगकर्ता डाला और फिर इसे डेटाबेस से लोड किया और अंत में कंसोल में लोड किए गए उपयोगकर्ता को दिखाया। हमने सफलतापूर्वक एक नया बनाया हैTypeORM अनुप्रयोग, इसे कॉन्फ़िगर किया है और अनुप्रयोग चलाएँ।

हम इस बारे में चर्चा करेंगे कि आगामी अध्यायों में डेटा को किस तरह से निष्पादित किया जाता है।

डेटाबेस के साथ बातचीत करने के लिए, हमें डेटाबेस से कनेक्शन ऑब्जेक्ट की आवश्यकता होती है। डेटाबेस ऑपरेशन करने से पहले हमें एक कनेक्शन ऑब्जेक्ट बनाने की आवश्यकता है और डेटाबेस ऑपरेशन किए जाने के बाद इसे समाप्त करना होगा। आइए इस खंड में TypeORM द्वारा प्रदान किए गए कनेक्शन एपीआई के बारे में जानें।

एक नया संबंध बनाना

एक नया कनेक्शन बनाने से पहले, हमें डेटाबेस कनेक्शन विवरण को कॉन्फ़िगर करने की आवश्यकता है ormconfig.jsonविन्यास फाइल। एक नमूना कनेक्शन विवरण नीचे दिखाया गया है -

ormconfig.json

{ 
   name: "firstconnection", 
   type: "mysql", 
   host: "localhost", 
   port: 3306, 
   username: "root", 
   password: "root", 
   database: "firstDB" 
}

यहाँ,

  • name - डेटाबेस कनेक्शन का नाम।
  • type - डेटाबेस।
  • host - डेटाबेस सर्वर का होस्टनाम।
  • port - डेटाबेस सर्वर पोर्ट।
  • username - डेटाबेस में खाता नाम।
  • password - उपर्युक्त खाते का पासवर्ड।
  • database - कनेक्ट करने के लिए डेटाबेस का नाम।

createConnection

CreateConnectionनया कनेक्शन बनाने के लिए TypeORM द्वारा विधि प्रदान की जाती है। यह नीचे के रूप में परिभाषित किया गया है,

import { createConnection, Connection } from "typeorm"; 

const connection = await createConnection({ 

});

यहाँ, createConnection ormconfig.json फ़ाइल में निर्दिष्ट कॉन्फ़िगरेशन विवरण का उपयोग करेगा।

वैकल्पिक रूप से, आप कनेक्शन URL को तर्कों के रूप में निर्दिष्ट विधि के रूप में परिभाषित कर सकते हैं -

const connection = createConnection({ type: 'mysql', 
     url: 'localhost:8888/firstDB' 
})

यहाँ,

createConnection किसी ऑब्जेक्ट को लौटाता है, जिसका उपयोग डेटाबेस से कनेक्शन को खोलने / बंद करने के लिए किया जा सकता है।

कई कनेक्शन

TypeORM कई डेटाबेस कनेक्शन बनाने के लिए एक विकल्प प्रदान करता है। सबसे पहले, कॉन्फ़िगरेशन फ़ाइल ormconfig.json का उपयोग कई डेटाबेस कनेक्शन के विवरण को निर्दिष्ट करने के लिए किया जा सकता है। बता दें कि ormconfig.json में कई डेटाबेस को निम्नानुसार कॉन्फ़िगर किया गया है,

ormconfig.json

{  name: "firstconnection", 
   type: "mysql", 
   host: "localhost", 
   port: 3306, 
   username: "root", 
   password: "root", 
   database: "firstDB" 
}, 
{  name: "secondconnection", 
   type: "mysql", 
   host: "localhost", 
   port: 3306, 
   username: "root", 
   password: "root", 
   database: "secondDB" 
}, 
{  name: "thirdconnection", 
   type: "mysql", 
   host: "localhost", 
   port: 3306, 
   username: "root", 
   password: "root", 
   database: "thirdDB" 
}

अब, हम कनेक्शन ऑब्जेक्ट बनाने के लिए कनेक्शन का नाम निर्दिष्ट करने के लिए createConnection विधि द्वारा दिए गए तर्क का उपयोग कर सकते हैं जैसा कि नीचे वर्णित है -

const firstconnection: Connection = await createConnection("firstconnection");

यहाँ,

createConnection के विन्यास विवरण का उपयोग करेगा firstconnection में निर्दिष्ट है ormconfig.json कनेक्शन ऑब्जेक्ट बनाने के लिए फ़ाइल।

टाइपऑर्म भी एक और एपीआई प्रदान करता है, एक बार और फिर कई कनेक्शन बनाने के लिए, जब भी आवश्यक हो, नीचे दिए गए अनुसार इसका उपयोग करें -

import { createConnections, Connection } from "typeorm"; 

const connections: Connection[] = await createConnections([ 

]);

यहाँ,

connections एक सरणी के रूप में सभी कनेक्शन वस्तुओं को पकड़ो।

ConnectionManager

टाइप करें कनेक्शन बनाने के लिए एक अन्य एपीआई, कनेक्शन प्रबंधक भी प्रदान करता है। यह नीचे परिभाषित किया गया है -

import {getConnectionManager, ConnectionManager, Connection} from "typeorm"; 

const connectionManager = getConnectionManager(); 

const connection = connectionManager.create({ 

}); 
await connection.connect();

टाइप के उपयोग को प्राथमिकता देता है createConnection ऊपर ConnectionManager कनेक्शन ऑब्जेक्ट बनाने के लिए।

एक इकाई फ़ील्ड और संबद्ध डेटाबेस संचालन का एक संग्रह है। यह डेटाबेस तालिका और उसके क्षेत्रों को संस्थाओं और उसकी विशेषताओं के साथ मैप करने के लिए उपयोग किया जाता है। यह अध्याय टाइप करें संस्थाओं के बारे में विस्तार से बताता है।

परिचय

आइए हम अपने कोड में एक साधारण इकाई वर्ग बनाते हैं। अपने प्रोजेक्ट रूट लोकेशन पर जाएं और src फोल्डर के अंदर जाकर एंट्री फोल्डर में जाएं। अब, टाइपस्क्रिप्ट फ़ाइल बनाएँ, Student.ts और कोड के नीचे दर्ज करें -

Student.ts

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class Student {   

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   Name: string; 
   
   @Column() 
   age: number; 
}

यहाँ,

  • Entity() डेकोरेटर वर्ग का उपयोग यह दर्शाने के लिए किया जाता है कि Student क्लास एक इकाई है।
  • PrimaryGeneratedColumn() डेकोरेटर क्लास का उपयोग यह दर्शाने के लिए किया जाता है कि आईडी कॉलम प्राथमिक कुंजी कॉलम है Student इकाई।
  • Column() डेकोरेटर वर्ग का उपयोग अन्य स्तंभों जैसे कि प्रतिनिधित्व करने के लिए किया जाता है Name तथा Age का Student इकाई।

अब, इकाई वर्ग Studentबनाया गया है। टाइपऑटो से संबंधित तालिका उत्पन्न होगीStudent हमारे डेटाबेस में इकाई और इसे नाम दिया जाएगा student। अब, करने के लिए कदमsrc/index.ts फ़ाइल और निम्न कोड जोड़ें -

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));

यहाँ,

  • पंक्ति 1 - 3 संबंधित वर्गों का आयात करती है, createConnection तथा Student
  • लाइन 5 डेटाबेस का उपयोग करके एक नया कनेक्शन बनाता है createConnection और यदि कनेक्शन स्थापित है, तो यह अंदर कोड को निष्पादित करता है then खंड मैथा।
  • लाइन 10 नए स्टूडेंट ऑब्जेक्ट, स्टड बनाते हैं।
  • लाइन 13-14 हमारे नए बनाए गए स्टड ऑब्जेक्ट की विशेषताओं को निर्धारित करती है।
  • लाइन 17 में उपलब्ध बचाव विधि का उपयोग करके डेटाबेस को इकाई बचाता है connection.manager वस्तु।
  • लाइन 23 में उपलब्ध खोज विधि का उपयोग करके डेटाबेस से छात्र का विवरण प्राप्त होता है connection.manager वस्तु।

Mysql सर्वर शुरू करें और अपना आवेदन चलाएं

हमने छात्र इकाई बनाई है और index.ts में कनेक्शन बनाते हैं। आइए हम MySql सर्वर और आपके आवेदन दोनों को शुरू करते हैं।

npm start

यह आपकी स्क्रीन पर निम्न आउटपुट लौटाएगा -

उत्पादन

खुला हुआ mysql सर्वर का पालन student तालिका आपके डेटाबेस के अंदर जोड़ी गई है।

कॉलम

जैसा कि पहले सीखा गया था, एंटिटी वास्तव में विशेषताओं का एक संग्रह है। के रूप में इकाई वस्तु डेटाबेस तालिका को संदर्भित करता है। इसकी विशेषताएँ / सदस्य चर संबंधित डेटाबेस तालिका के फ़ील्ड / कॉलम को संदर्भित करते हैं। प्रकार कॉलम वर्ग के माध्यम से सभी प्रकार के डेटाबेस फ़ील्ड का समर्थन करता है। आइए इस अध्याय में TypeORM द्वारा समर्थित विभिन्न प्रकार के कॉलम जानें।

@Column() डेकोरेटर वर्ग का उपयोग इकाई में कॉलम और उसके प्रकार का प्रतिनिधित्व करने के लिए किया जाता है।

उदाहरण के लिए, छात्र इकाई की आयु विशेषता और आयु विशेषता के प्रकार को नीचे परिभाषित किया जा सकता है -

@Column("int") age: integer; // OR @Column({ type: "int" }) age: integer;

यहाँ,

  • ageइकाई का गुण है। दूसरे शब्दों में, डेटाबेस में छात्र तालिका में आयु एक क्षेत्र / स्तंभ है।
  • int डेटाबेस में आयु कॉलम के प्रकार का प्रतिनिधित्व करते हैं।

टाइपफॉर्म लोकप्रिय डेटाबेस इंजन में उपलब्ध लगभग सभी प्रकारों का समर्थन करता है। दरअसल, टाइपफॉर्म प्रत्येक डेटाबेस इंजन के लिए विभिन्न प्रकार के सेट को सक्षम करता है। हम किसी भी मुद्दे के बिना हमारे डेटाबेस इंजन द्वारा समर्थित किसी भी डेटाबेस प्रकार का उपयोग कर सकते हैं।

उदाहरण के लिए, Postgresql डेटाबेस इंजन के लिए TypeORM द्वारा समर्थित प्रकार इस प्रकार है -

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

इसी प्रकार, टाइप करें MySQL के लिए डेटाटाइप के एक अलग सेट का समर्थन करता है।

कॉलम विकल्प

टाइप करें कॉलम का वर्णन करने के लिए प्रकार के अलावा अन्य विकल्पों का एक व्यापक सेट प्रदान करता है। उदाहरण के लिए, लंबाई विकल्प डेटाबेस फ़ील्ड की लंबाई को संदर्भित करता है और इसे नीचे के रूप में निर्दिष्ट किया जा सकता है -

@Column("varchar", { length: 100 })

सबसे आम कॉलम विकल्पों में से कुछ इस प्रकार हैं -

  • name - डेटाबेस फील्ड / कॉलम का नाम।
  • length - डेटाबेस फ़ील्ड / कॉलम की लंबाई।
  • nullable - निर्दिष्ट करें कि डेटाबेस फ़ील्ड / कॉलम नल की अनुमति देता है या नहीं।
  • default - डेटाबेस फ़ील्ड / कॉलम का डिफ़ॉल्ट मान।
  • primary - निर्दिष्ट करें कि डेटाबेस फ़ील्ड / स्तंभ तालिका की प्राथमिक कुंजी है या नहीं।
  • unique - निर्दिष्ट करें कि क्या डेटाबेस फ़ील्ड / स्तंभ अद्वितीय है
  • *precision** - डेटाबेस फील्ड / कॉलम की शुद्धता
  • scale - डेटाबेस फील्ड / कॉलम का स्केल
  • comment - डेटाबेस फील्ड / कॉलम की टिप्पणी या विवरण

@ तैयार डेकोरेटर

टाइप करें अतिरिक्त डेकोरेटर प्रदान करता है, @Generated को ऑटो मान स्तंभ मान उत्पन्न करता है। उदाहरण के लिए, किसी स्तंभ में अनन्य मान संग्रहीत करने के लिए डेटाबेस में उपयोग करने के लिए यूनिवर्सली यूनिक आइडेंटिफ़ायर (UUID) काफी आम है। UUID जनरेट करने के लिए नमूना कोड निम्नानुसार है -

@Entity() 
export class Student {
 
   @PrimaryColumn() 
   id: number; 
   
   @Column() 
   @Generated("uuid") 
   uuid: string; 
}

यहाँ,

uuid स्वचालित रूप से उत्पन्न होता है और डेटाबेस के अंदर संग्रहीत होता है।

प्राथमिक स्तंभ

डेटाबेस में किसी भी इकाई के लिए कम से कम एक प्राथमिक स्तंभ फ़ील्ड अनिवार्य है। इसे विभिन्न प्रकार के सज्जाकारों में वर्गीकृत किया गया है। हम एक-एक करके इसकी चर्चा करेंगे।

@PrimaryColumn()

@PrimaryColumn () डेकोरेटर का उपयोग किसी भी प्रकार के डेटा के लिए प्राथमिक कॉलम बनाने के लिए किया जाता है। सरल उदाहरण नीचे दिखाया गया है,

import {Entity, PrimaryColumn} from "typeorm"; 

@Entity() 
export class Student {        
@PrimaryColumn() 
   id: number; 
}

यहाँ,

id एक पूर्णांक है, जो डुप्लिकेट मानों को स्वीकार नहीं करता है, लेकिन हमें मूल्यों को असाइन करने की आवश्यकता है।

हम स्थिति के अनुसार एक या अधिक फ़ील्ड के लिए प्राथमिक कॉलम असाइन कर सकते हैं।

उदाहरण

import {Entity, PrimaryColumn} from "typeorm"; 

@Entity() 
export class Student { 
   
   @PrimaryColumn() 
   id: number; 
   
   @PrimaryColumn() 
   email: string; 
   
   @PrimaryColumn() 
   phone: number; 
}

@PrimaryGeneratedColumn ()

@PrimaryGeneratedColumn()फ़ील्ड का उपयोग प्राथमिक कॉलम के साथ-साथ डेटाबेस में कॉलम मान उत्पन्न करने के लिए ऑटो को निर्दिष्ट करने के लिए किया जाता है। यह नीचे दिखाया गया है -

import {Entity, PrimaryGeneratedColumn} from "typeorm"; 

@Entity() 
export class Student {

   @PrimaryGeneratedColumn() 
   id: number;
}

यहाँ,

आपको आईडी मान निर्दिष्ट नहीं करना है; यह डेटाबेस तालिका में TypeORM द्वारा स्वचालित रूप से उत्पन्न किया जाएगा।

@PrimaryGeneratedColumn ( "UUID")

@PrimaryGeneratedColumn भी जनरेटर के प्रकार को निर्दिष्ट करने के लिए एक तर्क को स्वीकार करता है। मुख्य उपयोग में से एक यूयूआईडी के आधार पर अद्वितीय आईडी उत्पन्न करना है।

import {Entity, PrimaryGeneratedColumn} from "typeorm";

@Entity() 
export class Student {  
   @PrimaryGeneratedColumn("uuid") id: string; 
}

सरल-सरणी कॉलम प्रकार

उन्नत संबंधपरक डेटाबेस सरणी डेटाटाइप का समर्थन करता है। सरणी डेटाटाइप का समर्थन करने के लिए, टाइप करें एक विशेष कॉलम प्रकार प्रदान करता है, आदिम सरणी मूल्यों को संग्रहीत करने के लिए "सरल-सरणी"। इसका उपयोग करने के लिए एक नमूना कोड निम्नानुसार है -

@Entity() 
export class Student { 
   
   @PrimaryGeneratedColumn() 
   id: number;

   @Column("simple-array") 
   names: string[]; 
}

सरल- json कॉलम प्रकार

आधुनिक डेटाबेस इंजन का बहुत JSON डेटाबेस का समर्थन करता है। JSON डेटाटाइप का उपयोग करने के लिए, टाइप करें एक विशेष प्रकार, सिंगल-जेनसन प्रदान करता है। इसका उपयोग करने के लिए नमूना कोड निम्नानुसार है -

@Entity() 
export class Student { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column("simple-json")
   info: { firstName: string, middleName: string, lastName: string }; 
}

इस मान को index.ts में परिभाषित किया जा सकता है,

index.ts

const stud = new Student(); 
stud.info = { firstName: "John", middleName: "peter", lastName: "Michael" };

विशेष स्तंभ

टाइप करें निम्न विशेष स्तंभों का समर्थन करता है

  • @CreateDateColumn - यह स्वचालित रूप से इकाई की प्रविष्टि तिथि निर्धारित करने के लिए एक विशेष स्तंभ है।
  • @UpdateDateColumn - इसका उपयोग इकाई के अद्यतन समय को स्वचालित रूप से सेट करने के लिए किया जाता है।
  • @VersionColumn - स्वचालित रूप से इकाई के लिए संस्करण संख्या सेट करें।

इकाई इनहेरिटेंस

संस्थाओं के दोहराव को कम करने के लिए इकाई विरासत का उपयोग किया जाता है। नीचे की संस्थाओं पर विचार करें -

Result.ts

@Entity() 
export class Result {    

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   title: string; 
   
   @Column() 
   description: string; 
   
   @Column() 
   eligible: string 
}

Grade.ts

ग्रेड के लिए कोड निम्नानुसार है -

@Entity() 
export class Grade {

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @Column() 
   title: string; 
   
   @Column() 
   description: string;
   
   
   
   @Column() 
   grading : string; 
}

यहाँ,

उपरोक्त दो संस्थाओं में कॉलम आईडी, शीर्षक और विवरण है। एंटिटी इनहेरिटेंस का उपयोग करते हुए, हम एक बेस क्लास विवरण बनाते हैं और उपरोक्त दोनों संस्थाओं को नीचे बताए अनुसार जोड़ते हैं।

Details.ts

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; 
}

अब अपना सर्वर शुरू करें, आप नीचे दी गई प्रतिक्रिया देख सकते हैं,

अब अपना mysql सर्वर खोलें और अपने डेटाबेस में जाएँ, आप निम्न तालिकाओं को देख सकते हैं,

ग्रेड टेबल

परिणाम तालिका

डेटाबेस में तालिका के बीच संबंध को संदर्भित करने के लिए संबंधों का उपयोग किया जाता है। सामान्य तौर पर, एक संबंध दो तालिकाओं के बीच मौजूद होता है जब उनमें से एक में एक विदेशी कुंजी होती है जो अन्य तालिका की प्राथमिक कुंजी को संदर्भित करती है। यह सुविधा रिलेशनल डेटाबेस को अधिक शक्तिशाली और कुशलतापूर्वक जानकारी संग्रहीत करती है।

TypeORM संस्थाओं को एक दूसरे से और बाद में डेटाबेस तालिकाओं से संबंधित होने की अनुमति देता है। सामान्य तौर पर, रिश्ते को चार व्यापक श्रेणियों में वर्गीकृत किया जा सकता है। वे इस प्रकार हैं,

one-to-one- दी गई इकाई की एक वस्तु लक्ष्य इकाई के केवल एक वस्तु से संबंधित है और इसके विपरीत। उदाहरण के लिए, एक देश के पास केवल एक राजधानी शहर होगा और इसी तरह एक शहर केवल एक देश की राजधानी होगा।

many-to-one- दी गई इकाई का एक से अधिक ऑब्जेक्ट लक्ष्य इकाई के एक ऑब्जेक्ट से संबंधित है। उदाहरण के लिए, शहर केवल एक देश के अंतर्गत आता है, लेकिन देश में कई शहर हो सकते हैं।

one-to-many - रिलेशनशिप को छोड़कर एक-से-एक कई एक ही होते हैं।

many-to-many- दी गई इकाई की कई वस्तु लक्ष्य इकाई के कई उद्देश्य से संबंधित है। उदाहरण के लिए, एक लेख को प्रोग्रामिंग भाषा, वित्त, आदि जैसे कई विषयों के तहत टैग किया जा सकता है, और साथ ही एक विशेष टैग में कई लेख भी हो सकते हैं।

टंकण भी संस्थाओं के संबंधों को बढ़ाने के लिए विकल्प प्रदान करता है। वे इस प्रकार हैं -

  • eager - स्रोत इकाई वस्तु लक्ष्य इकाई वस्तुओं को भी लोड करती है।
  • cascade - लक्ष्य इकाई वस्तु सम्मिलित या अद्यतन की जाती है, जबकि स्रोत इकाई वस्तु डाली या अद्यतन की जाती है।
  • onDelete - लक्ष्य निकाय ऑब्जेक्ट तब तक हटा दिए जाते हैं जब स्रोत इकाई ऑब्जेक्ट हटा दिया जाता है।
  • primary - यह निर्दिष्ट करने के लिए उपयोग किया जाता है कि संबंध स्तंभ प्राथमिक कुंजी है या नहीं।
  • nullable - यह निर्दिष्ट करने के लिए उपयोग किया जाता है कि संबंध स्तंभ अशक्त है या नहीं।

आइए हम विस्तार से विभिन्न प्रकार के संबंध मानचित्रण के माध्यम से जाते हैं।

एक से एक

जैसा कि हमने पहले सीखा था, यह एक तालिका फ़ील्ड के उदाहरण से संदर्भित होता है जिसमें अन्य तालिका फ़ील्ड का उदाहरण होता है और इसके विपरीत। आइये हम बनाते हैंDetails तालिका -

Details.ts

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm";

@Entity() 
export class Details {
   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   gender: string; 
   
   @Column() 
   country: string; 
}

चलिए एक अन्य इकाई ग्राहक बनाते हैं -

Customer.ts

import {Entity, PrimaryGeneratedColumn, Column, OneToOne, JoinColumn} from "typeorm"; 

import {Details} from "./Details"; 

@Entity() 
export class Customer { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @OneToOne(type => Details) @JoinColumn() 
   details: Details;
}

यहाँ,

हमने मैपिंग को जोड़ा है OneToOne सेवा Details तालिका। @JoinColumn() "संबंध आईडी" और विदेशी कुंजी शामिल करें Customerतालिका। हम संबंध को बचा सकते हैंindex.ts निम्नानुसार है -

const details = new Details(); details.gender = "female"; details.country = "india" await connection.manager.save(details);

const customer = new Customer(); customer.name = 'customer1'; customer.details = Details; await connection.manager.save(Customer);

एक-से-एक और कई-से-एक

जैसा कि हमने पहले सीखा था, यह पहली तालिका फ़ील्ड के उदाहरण से संदर्भित है जिसमें द्वितीय तालिका फ़ील्ड के कई उदाहरण हैं One-to-Many पहली तालिका के मानचित्रण और कई उदाहरणों में दूसरी तालिका का केवल एक उदाहरण है Many-to-One मानचित्रण।

के एक उदाहरण पर विचार करें Student तथा project संस्थाएं, जबकि छात्र एक से अधिक परियोजनाओं पर काम कर सकते हैं, लेकिन प्रत्येक परियोजना को केवल एक छात्र द्वारा नियंत्रित किया जाता है।

आइए बनाते हैं a Project इकाई निम्नानुसार है -

परियोजना

import {Entity, PrimaryGeneratedColumn, Column, ManyToOne} from "typeorm"; import {Student} from "./Student"; 
@Entity() 
export class Project {  

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   projects: string; 
   
   @ManyToOne(type => Student, student => student.projects) student: Student; 
}

अब, हम बनाते हैं Student नीचे के रूप में इकाई -

import {Entity, PrimaryGeneratedColumn, Column, OneToMany} from "typeorm"; import {Project} from "./Project"; 

@Entity() 
export class User {  
   
   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @OneToMany(type => Project, project => project.student) projects: Project[];  
}

यहाँ,

@OneToMany संपत्ति मैप की गई Project तथा @ManyToOne संपत्ति मैप की गई Student। तथापि,@OneToMany बिना अस्तित्व में नहीं रह सकता @ManyToOne तथा @ManyToOne संपत्ति में "संबंध आईडी" और विदेशी कुंजी शामिल है।

हम कनेक्शन को इसमें सहेज सकते हैं index.ts निम्नानुसार है -

const proj1 = new Project(); proj1.projects = "database management"; await connection.manager.save(proj1); 

const proj2 = new Project(); proj2.projects = "web application"; await connection.manager.save(proj2); 

const stud = new Student(); stud.name = "Student1"; stud.projects = [proj1, proj2]; await connection.manager.save(stud);

कई कई

जैसा कि हमने पहले सीखा, यह एक तालिका में कई अभिलेखों द्वारा संदर्भित किया जाता है, एक तालिका में कई अभिलेखों से संबंधित हैं। एक उदाहरण पर विचार करें, विश्वविद्यालय के छात्र को एक बार में कई वर्गों में नामांकित किया जा सकता है जिसका अर्थ है कि छात्र के पास प्रति सेमेस्टर चार या पांच कक्षाएं हो सकती हैं और एक कक्षा में कई छात्र हो सकते हैं।

हम बस निष्कर्ष निकाल सकते हैं, एक छात्र के पास कई कक्षाएं हैं, और एक कक्षा में कई छात्र हैं। के लिए एक इकाई बनाते हैंClasses निम्नानुसार है -

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class Classes { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
}

अब, हम बनाते हैं Student नीचे के रूप में इकाई -

import {Entity, PrimaryGeneratedColumn, Column, ManyToMany, JoinTable} from "typeorm"; 
import {Classes} from "./Classes";

@Entity() 
export class Student { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string;

   @Column() 
   subjects: string; 
   
   @ManyToMany(type => Classes) @JoinTable() 
   classes: Classes[];
}

रिपॉजिटरी एक इकाई के लिए विशिष्ट है। दूसरे शब्दों में, प्रत्येक इकाई का अपना, बिल्ड-इन रिपॉजिटरी होगा और इसे नीचे दिए गए अनुसार कनेक्शन ऑब्जेक्ट की getRepository () विधि का उपयोग करके एक्सेस किया जा सकता है -

const studRepository = manager.getRepository(Student);

छात्र रिपॉजिटरी ऑब्जेक्ट बन जाने के बाद, इसका उपयोग छात्र ऑब्जेक्ट के सभी डेटाबेस ऑपरेशन को करने के लिए किया जा सकता है।

रिपोजिटरी प्रकार

Repositoryचार श्रेणियों में वर्गीकृत किया गया है। वे इस प्रकार हैं -

कोष

एक इकाई का डिफ़ॉल्ट भंडार और इसका उपयोग करके पहुँचा जा सकता है getRepository() नीचे बताए अनुसार विधि -

const studRepository = manager.getRepository(Student);

अभी, studRepository छात्र तालिका को क्वेरी करने के लिए उपयोग किया जा सकता है

TreeRepository

संरचना संस्थाओं की तरह पेड़ के लिए उपयोग किया जाता है और इसका उपयोग करके पहुँचा जा सकता है getTreeRepository() नीचे बताए अनुसार विधि -

const studcaRepository = manager.getTreeRepository(Student);

MongoRepository

MongoDB संचालन संस्थाओं के अंदर उपयोग किया जाता है और इसका उपयोग करके पहुँचा जा सकता है getMongoRepository() नीचे बताए अनुसार विधि -

const detailsRepository = manager.getMongoRepository(Details);

CustomRepository

रिपॉजिटरी को अनुकूलित करने के लिए उपयोग किया जाता है और इसका उपयोग करके पहुँचा जा सकता है getCustomRepository() नीचे दी गई विधि के अनुसार,

const myUserRepository = manager.getCustomRepository(UserRepository);

रिपोजिटरी एपीआई

आइये इस अध्याय में EntityManager की सबसे महत्वपूर्ण विधि जानें।

मैनेजर

हम पहुंच सकते हैं EntityManager नीचे बताए अनुसार प्रबंधक विधि का उपयोग करना -

const manager = repository.manager;

queryRunner

queryRunnerविधि कस्टम क्वेरी रनर ऑब्जेक्ट देता है और इसका उपयोग रिपॉजिटरी द्वारा डेटाबेस संचालन के लिए किया जाता है। नमूना कोड इस प्रकार है -

const queryRunner = repository.queryRunner;

मेटाडाटा

metadataरिपोजिटरी का मेटाडेटा लौटाता है। नमूना कोड इस प्रकार है -

const metadata = repository.metadata;

सवाल

queryपद्धति SQL प्रश्नों को निष्पादित करती है। नीचे दिखाए गए अनुसार सरल चयन क्वेरी -

const qur = await repository.query(`select * from students`);

डालने

insertडेटाबेस में एक नई इकाई या संस्थाओं की सरणी डालने के लिए विधि का उपयोग किया जाता है। नमूना कोड इस प्रकार है -

await repository.insert({ 
   Name: "Student3", 
   Age: 14 
});

उपरोक्त क्वेरी के बराबर है,

insert into student(Name,age) values("Student3",14)

अपडेट करें

update डेटाबेस में मौजूदा रिकॉर्ड को अपडेट करने के लिए उपयोग किया जाता है।

await repository.update(1, { Name: "Adam" });

यह क्वेरी नीचे बताए गए के समान काम करती है -

update student SET Name = "Adam" where id = 1

हटाना

delete विधि तालिका से निर्दिष्ट रिकॉर्ड को हटा देगी,

await repository.delete(Student, 1);

यह छात्र को आईडी के साथ हटा देगा 1 वहाँ से studentतालिका। यह के बराबर है,

delete from student where id=1;

यदि आप नाम से हटाना चाहते हैं तो नीचे दिए गए क्वेरी का उपयोग करें,

await repository.delete({ Name: "Student1" });

यह क्वेरी नाम वाले सभी छात्र को हटा देगी, Student1

** सॉफ्टडेट और रीस्टोर **

इसका उपयोग डेटा को नरम करने के लिए किया जाता है और आप छात्र की आईडी के आधार पर रिकॉर्ड को पुनर्स्थापित कर सकते हैं। नमूना कोड इस प्रकार है -

await repository.softDelete(1);

आप नीचे दिए गए आदेश का उपयोग करके छात्र के रिकॉर्ड को पुनर्स्थापित कर सकते हैं -

await repository.restore(1);

हटाने और पुनर्स्थापित करने का एक वैकल्पिक विकल्प उपयोग करना है softRemove तथा recoverतरीकों। नमूना कोड इस प्रकार है -

//find the entities const enty = await repository.find(); 

//soft removed entity const entySoftRemove = await repository.softRemove(enty);

और, आप नीचे बताए अनुसार पुनर्प्राप्त विधि का उपयोग करके उन्हें पुनर्प्राप्त कर सकते हैं,

await repository.recover(entySoftRemove);

सहेजें

saveडेटाबेस में दिए गए निकाय को बचाने के लिए उपयोग किया जाता है। सरल छात्र इकाई को नीचे दिखाए अनुसार सहेजा जा सकता है -

import {Student} from "./entity/Student"; 

createConnection().then(async connection => {                     
   console.log("Inserting a new record into the student database..."); 
   const stud = new Student();
   stud.Name = "student1"; 
   stud.age = 12; 
   await repository.save(stud);

यह डेटाबेस में नया छात्र रिकॉर्ड जोड़ेगा।

हटाना

removeडेटाबेस से दिए गए निकाय को हटाने के लिए उपयोग किया जाता है। सरल छात्र इकाई को नीचे दिखाए अनुसार हटाया जा सकता है -

await repository.remove(stud);

गिनती

countविधि तालिका में उपलब्ध अभिलेखों की संख्या लौटाएगी और आप इसका उपयोग पृष्ठांकन उद्देश्यों के लिए कर सकते हैं। नमूना कोड इस प्रकार है -

const cnt = await repository.count(Student, { age: 12 });

खोज

findखोज उद्देश्यों के लिए विधि का उपयोग किया जाता है। यह डेटाबेस से सभी रिकॉर्ड प्राप्त करता है जैसा कि नीचे दिखाया गया है -

const result = await repository.find({ id: 1 });

ढूँढो एक

के समान findविधि, लेकिन पहला मिलान रिकॉर्ड लौटाता है। नमूना कोड इस प्रकार है -

const result = await repository.findOne({ id: 1 });

स्पष्ट

clearपद्धति तालिका से सभी डेटा को साफ करती है। नमूना कोड इस प्रकार है -

await repository.clear();

EntityManager के समान है Repositoryऔर डेटा डालने, अद्यतन करने, हटाने और लोड करने जैसे डेटाबेस संचालन का प्रबंधन करने के लिए उपयोग किया जाता है। जबकिRepository एकल इकाई संभालती है, EntityManager सभी संस्थाओं के लिए सामान्य है और सभी संस्थाओं पर संचालन करने में सक्षम है।

इकाई प्रबंधक एपीआई

हम पहुंच सकते हैं EntityManager का उपयोग करते हुए getManager() नीचे बताए अनुसार विधि -

import { getManager } from "typeorm"; const entityManager = getManager();

आइये इस अध्याय में EntityManager की सबसे महत्वपूर्ण विधि जानें।

संबंध

connectionविधि विशिष्ट डेटाबेस के लिए डेटाबेस ORM कनेक्शन देता है। नमूना कोड इस प्रकार है -

const connection = manager.connection;

QueryRunner

queryRunnerविधि कस्टम क्वेरी रनर ऑब्जेक्ट देता है और इसका उपयोग इकाई प्रबंधक द्वारा डेटाबेस संचालन के लिए किया जाता है। नमूना कोड इस प्रकार है -

const queryRunner = manager.queryRunner;

लेन-देन

यदि एकाधिक डेटाबेस अनुरोधों को कहा जाता है, तो लेनदेन एकल डेटाबेस लेनदेन में निष्पादित होगा। लेनदेन प्राप्त करने के लिए नमूना कोड इस प्रकार है -

await manager.transaction(async manager => { 
});

सवाल

queryविधि एसक्यूएल प्रश्नों को निष्पादित करती है। नीचे दिए गए अनुसार सरल सम्मिलित क्वेरी -

const qur = await manager.query(`insert into student(name,age) values('stud2',13)`);

डालने

insertडेटाबेस में एक नई इकाई या संस्थाओं की सरणी डालने के लिए विधि का उपयोग किया जाता है। नमूना कोड इस प्रकार है -

await manager.insert(Student, { 
   Name: "Student3", 
   Age: 14 
});

अपडेट करें

update डेटाबेस में मौजूदा रिकॉर्ड को अपडेट करने के लिए उपयोग किया जाता है।

await manager.update(User, 1, { Name: "Adam" });

यह क्वेरी नीचे दिए गए SQL क्वेरी के समान काम करती है,

UPDATE student SET Name = "Adam" WHERE id = 1

हटाना

हटाने की विधि तालिका से निर्दिष्ट रिकॉर्ड को हटा देगी,

await manager.delete(Student, 1);

यह स्टूडेंट रिकॉर्ड के आईडी 1 के साथ डिलीट हो जाएगा।

सहेजें

saveडेटाबेस में दिए गए निकाय को बचाने के लिए उपयोग किया जाता है। सरल छात्र इकाई को नीचे दिखाए अनुसार सहेजा जा सकता है -

import {Student} from "./entity/Student";

createConnection().then(async connection => {   
   console.log("Inserting a new record into the student database..."); 
   const stud = new Student(); stud.Name = "student1"; 
   stud.age = 12; 
   await connection.manager.save(stud); 
}

यह डेटाबेस में नया छात्र रिकॉर्ड जोड़ेगा। यदि छात्र दिए गए डेटाबेस में मौजूद नहीं है, तो सेव मेथड छात्र को सम्मिलित करेगा। अन्यथा, सहेजें डेटाबेस में मौजूदा छात्र रिकॉर्ड को अपडेट करेगा।

हटाना

removeडेटाबेस से दिए गए निकाय को हटाने के लिए उपयोग किया जाता है। सरल छात्र इकाई को नीचे दिखाए अनुसार हटाया जा सकता है -

await manager.remove(stud);

गिनती

countविधि तालिका में उपलब्ध अभिलेखों की संख्या लौटाएगी और आप इसका उपयोग पृष्ठांकन उद्देश्यों के लिए कर सकते हैं। नमूना कोड इस प्रकार है -

const cnt = await manager.count(Student, { age: 12 });

खोज

findखोज उद्देश्यों के लिए विधि का उपयोग किया जाता है। यह डेटाबेस से सभी रिकॉर्ड प्राप्त करता है जैसा कि नीचे दिखाया गया है -

console.log("Loading users from the database..."); 
const students = await connection.manager.find(Student); console.log("Loaded users: ", students);

ढूँढो एक

के समान findविधि, लेकिन पहला मिलान रिकॉर्ड लौटाता है। नमूना कोड इस प्रकार है -

const stud = await manager.findOne(Student, 1);

स्पष्ट

स्पष्ट विधि तालिका से सभी डेटा को साफ करती है। नमूना कोड इस प्रकार है -

await manager.clear(Student);

क्वेरी बिल्डर एक आसान तरीके से जटिल एसक्यूएल प्रश्नों का निर्माण किया जाता है। इसे कनेक्शन विधि और QueryRunner ऑब्जेक्ट्स से प्रारंभ किया गया है।

हम तीन तरीकों से QueryBuilder बना सकते हैं।

संबंध

कनेक्शन विधि का उपयोग करके QueryBuilder का उपयोग करने के एक सरल उदाहरण पर विचार करें।

import {getConnection} from "typeorm"; 

const user = await getConnection() .createQueryBuilder() 
.select("user") 
.from(User, "user") 
.where("user.id = :id", { id: 1 }) .getOne();

इकाई प्रबंधक

आइए निम्नानुसार इकाई प्रबंधक का उपयोग करके एक क्वेरी बिल्डर बनाएं -

import {getManager} from "typeorm"; 

const user = await getManager() .createQueryBuilder(User, "user") .where("user.id = :id", { id: 1 })    .getOne();

कोष

हम क्वेरी बिल्डर बनाने के लिए रिपॉजिटरी का उपयोग कर सकते हैं। यह नीचे वर्णित है,

import {getRepository} from "typeorm"; 

const user = await getRepository(User) .createQueryBuilder("user") .where("user.id = :id", { id: 1 }) .getOne();

उपनाम

उपनाम SQL उपनाम के समान हैं। हम नीचे वर्णित अनुसार QueryBuilder का उपयोग करके छात्र तालिका के लिए उपनाम बनाते हैं -

import {getConnection} from "typeorm"; 

const user = await getConnection() .createQueryBuilder() 
.select("stud") 
.from(Student, "stud")

यह क्वेरी इसके बराबर है

select * from students as stud

मापदंडों

Parametersक्वेरी में गतिशील मानों के लिए प्लेसहोल्डर के रूप में उपयोग किया जाता है। कई मामलों में, विभिन्न इकाई ऑब्जेक्ट को खोजने के लिए क्वेरी मानों को छोड़कर समान होगी। उदाहरण के लिए, अलग-अलग छात्र को खोजने के लिए क्वेरी को छोड़कर एक ही हैStudent IDडेटा। इस स्थिति में, हम पैरामीटर का उपयोग कर सकते हैंStudent ID और फिर विभिन्न छात्र वस्तुओं को प्राप्त करने के लिए पैरामीटर बदलें।

SQL इंजेक्शन को रोकने के लिए पैरामीटर का एक और महत्वपूर्ण उपयोग है। यह आधुनिक वेब एप्लिकेशन में महत्वपूर्ण सुरक्षा उल्लंघन में से एक है। क्वेरी में पैरामीटर का उपयोग करके, हम SQL इंजेक्शन हमलों से बच सकते हैं।

SQL इंजेक्शन को रोकने के लिए पैरामीटर का एक और महत्वपूर्ण उपयोग है। यह आधुनिक वेब एप्लिकेशन में महत्वपूर्ण सुरक्षा उल्लंघन में से एक है। क्वेरी में पैरामीटर का उपयोग करके, हम SQL इंजेक्शन हमलों से बच सकते हैं।

उदाहरण के लिए

"student.id = :id", { id: 1 }

यहाँ,

: आईडी - पैरामीटर नाम।

{आईडी: 1} - पैरामीटर का मान

अभिव्यक्ति जोड़ना

यह खंड अभिव्यक्ति का उपयोग करने के तरीके के बारे में बताता है।

कहाँ पे

where यदि स्थिति का मिलान किया जाता है तो रिकॉर्ड को फ़िल्टर करने के लिए उपयोग किया जाता है।

createQueryBuilder("student") .where("student.id = :id", { id: 1 })

यह क्वेरी इसके बराबर है

select * from students student where student.id=1;

हम अंदर की स्थितियों के लिए AND, OR, NOT, का भी उपयोग कर सकते हैं।

बीत रहा है

सरल होने की अभिव्यक्ति नीचे दी गई है -

createQueryBuilder("student") .having("student.id = :id", { id: 1 })

यह क्वेरी इसके बराबर है

select * from students student having student.id=1;

द्वारा आदेश

ऑर्डरबी का उपयोग क्षेत्र के आधार पर रिकॉर्ड को सॉर्ट करने के लिए किया जाता है।

createQueryBuilder("student") .orderBy("student.name")

यह क्वेरी इसके बराबर है

select * from students student order by student.name;

समूह द्वारा

इसका उपयोग निर्दिष्ट कॉलम के आधार पर रिकॉर्ड को समूहित करने के लिए किया जाता है।

createQueryBuilder("student") .groupBy("student.id")

यह क्वेरी इसके बराबर है

select * from students student group by student.id;

सीमा

इसका उपयोग पंक्तियों के चयन को सीमित करने के लिए किया जाता है। नीचे, उदाहरण से पता चलता है कि क्वेरी बिल्डर में सीमा का उपयोग कैसे करें,

createQueryBuilder("student") .limit(5)

यह क्वेरी इसके बराबर है

select * from students student limit 5;

ओफ़्सेट

ऑफसेट का उपयोग यह निर्दिष्ट करने के लिए किया जाता है कि परिणाम को छोड़ने के लिए कितनी पंक्तियाँ हैं। यह नीचे परिभाषित किया गया है -

createQueryBuilder("student") .offset(5)

यह क्वेरी इसके बराबर है

select * from students student offset 5;

मिलती है

ज्वाइन क्लॉज का उपयोग संबंधित कॉलम के आधार पर दो या अधिक तालिकाओं से पंक्तियों को संयोजित करने के लिए किया जाता है। दो संस्थाओं पर विचार करें -

Student.ts

import {Entity, PrimaryGeneratedColumn, Column, OneToMany} from "typeorm"; 
import {Project} from "./Project"; 

@Entity() 
export class User {
   
   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @OneToMany(type => Project, project => project.student) projects: project[]; 
}

Project.ts

import {Entity, PrimaryGeneratedColumn, Column, ManyToOne} from "typeorm"; 
import {Student} from "./Student"; 

@Entity() 
export class Project { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   title: string; 
   
   @ManyToOne(type => Student, student => student.projects) student: Student; 
}

आइए नीचे दिए गए क्वेरी का उपयोग करते हुए सरल बाईं ओर करें -

const student = await createQueryBuilder("student") .leftJoinAndSelect("student.projects", "project") 
.where("student.name = :name", { name: "Student1" }) 
.getOne();

यह क्वेरी इसके बराबर है

SELECT student.*, project.* FROM students student 
   LEFT JOIN projects project ON project.student = student.id 
   WHERE student.name = 'Student1'

इसी तरह, हम भीतर से भी जुड़ने की कोशिश कर सकते हैं।

चयन के बिना शामिल हों

हम चुनिंदा का उपयोग किए बिना डेटा में शामिल हो सकते हैं। आइए हम इस उदाहरण का उपयोग करके इनर जॉइन का प्रयास करें -

const student = await createQueryBuilder("student") .innerJoin("student.projects", "project") 
   .where("student.name = :name", { name: "student1" }) 
   .getOne();

उपरोक्त क्वेरी इसके बराबर है -

SELECT student.* FROM students student 
   INNER JOIN projects project ON project.student = student.id 
   WHERE student.name = 'Student1';

पृष्ठ पर अंक लगाना

यदि आपके आवेदन में अधिक डेटा है, तो आपको पेजेशन, पेज स्लाइडर या स्क्रॉलिंग फ़ंक्शंस की आवश्यकता है।

उदाहरण के लिए, यदि आप अपने आवेदन में पहले पाँच छात्रों की परियोजनाएँ दिखाना चाहते हैं,

const students = await getRepository(Student) .createQueryBuilder("student") .leftJoinAndSelect("student.projects", "project") 
   .take(5) 
   .getMany();

सबक्वेरी

इसे किसी अन्य क्वेरी या नेस्टेड क्वेरी के भीतर क्वेरी कहा जाता है। हम FROM, WHERE और JOIN अभिव्यक्तियों में उपश्रेणियों का उपयोग करते हैं।

सरल उदाहरण नीचे दिखाया गया है -

const projects = await connection .createQueryBuilder() .select("project.id", "id")
.addSelect(subQuery => { 
   return subQuery 
      .select("student.name", "name") .from(Student, "student") 
      .limit(1); 
}, "name")
.from(Project, "project") .getMany();

छिपाया गया क्षेत्र

यदि आपके किसी कॉलम फ़ील्ड को {select: false} के रूप में चिह्नित किया जाता है, तो उस कॉलम को हिडन कॉलम माना जाता है। नीचे की इकाई पर विचार करें -

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class Student {

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @Column({select: false}) 
   address: string; 
}

यहाँ,

address फ़ील्ड के रूप में चिह्नित है hidden। हम प्रयोग कर सकते हैंaddSelectस्तंभ से जानकारी प्राप्त करने की विधि। यह नीचे परिभाषित किया गया है,

const student = await connection.getRepository(Student) .createQueryBuilder() .select("student.id", "student")    .addSelect("student.address") .getMany();

getSql ()

क्वेरी बिल्डर द्वारा उत्पन्न SQL क्वेरी प्राप्त करने के लिए इस विधि का उपयोग किया जाता है। यह नीचे परिभाषित किया गया है -

const sql = createQueryBuilder("student") .where("student.name = :name", { name: "Student1" })  .orWhere("student.age = :age", { age: 14 }) 
.getSql();

डेटा हेरफेर का उपयोग डेटा को प्रबंधित करने और देखने के लिए किया जाता है। यह अनुभाग QueryBuilder का उपयोग करके प्रश्नों को सम्मिलित करने, अपडेट करने, चयन करने और हटाने जैसे डेटाबेस प्रश्नों तक पहुंचने के बारे में बताता है। आइए एक एक करके विस्तार से देखें।

सम्मिलित क्वेरी बनाएँ

आइए हम एक ग्राहक इकाई बनाते हैं -

Customer.ts

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 
@Entity() 
export class Customer {       

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   name: string; 
   
   @Column() 
   age: number; 
}

आइए index.ts में निम्न बदलाव इस प्रकार जोड़ें -

index.ts

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Customer} from "./entity/Customer"; 
import {getConnection} from "typeorm"; 

createConnection().then(async connection => { 
   await getConnection().createQueryBuilder()   .insert() 
      .into(Customer)  
      .values([ { name: "Adam",age:11}, 
         { name: "David",age:12} ]) .execute(); 
}).catch(error => console.log(error));

अब, नीचे दिए गए आदेश का उपयोग करके अपना आवेदन शुरू करें -

npm start

उत्पादन

आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं -

अब अपना mysql सर्वर खोलें, तालिका को नीचे दिखाए गए अनुसार दो क्षेत्रों के साथ डाला गया है -

अद्यतन क्वेरी बनाएँ

अंतिम खंड, हमने डेटा की दो पंक्तियाँ डाली हैं। आइए देखें कि क्वेरी कैसे काम करती है। Index.ts में निम्न परिवर्तन निम्नानुसार जोड़ें -

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Customer} from "./entity/Customer"; 
import {getConnection} from "typeorm";

createConnection().then(async connection => { 

await getConnection()         
   .createQueryBuilder() .update(Customer) 
   .set({ name: "Michael" }) .where("id = :id", { id: 1 }) .execute(); 
   console.log("data updated"); 
   
}).catch(error => console.log(error));

अब, नीचे दिए गए आदेश का उपयोग करके अपना आवेदन शुरू करें -

npm start

आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं -

नीचे दिखाए गए अनुसार माईसक्ल तालिका को संशोधित किया गया है -

चुनिंदा क्वेरी बनाएँ

selectक्वेरी का उपयोग तालिका से रिकॉर्ड प्रदर्शित करने के लिए किया जाता है। चलिए निम्नलिखित कोड जोड़ते हैंindex.ts निम्नानुसार है -

index.ts

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Customer} from "./entity/Customer"; 

createConnection().then(async connection => { 

   console.log("Display records from Customer table..."); 
   const cus = new Customer();

   console.log("Loading customers from the database..."); 
   const customers = await connection.manager.find(Customer); console.log("Loaded users: ", customers); 
}).catch(error => console.log(error));

आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं -

जहाँ अभिव्यक्ति

हमें ग्राहकों को फ़िल्टर करने के लिए क्वेरी में अभिव्यक्ति कहाँ जोड़ें। नमूना कोड इस प्रकार है -

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Customer} from "./entity/Customer"; 
import {getConnection} from "typeorm";

createConnection().then(async connection => { 
   const customer = await getConnection() .createQueryBuilder() .select("cus") 
   .from(Customer, "cus") .where("cus.id = :id", { id: 1 }) .getOne(); 
   
   console.log(customer); 
})
.catch(error => console.log(error));

उपरोक्त कार्यक्रम पहले आईडी रिकॉर्ड लौटाएगा। आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं,

इसी तरह, आप अन्य भाव भी आज़मा सकते हैं।

डिलीट क्वेरी बनाएँ

अंतिम अनुभाग, हमने डेटा डाला, अद्यतन और चयन किया है। आइए देखें कि क्वेरी कैसे हटाती है। Index.ts में निम्न परिवर्तन निम्नानुसार जोड़ें -

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Customer} from "./entity/Customer"; 
import {getConnection} from "typeorm"; 

createConnection().then(async connection => { 
   await getConnection() .createQueryBuilder() 
   .delete() 
   .from(Customer) 
   .where("id = :id", { id: 1 }) .execute();
console.log("data deleted"); }).catch(error => console.log(error));

आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं -

और आपके mysql तालिका को निम्नानुसार संशोधित किया गया है -

आम तौर पर, लेनदेन एक तर्क इकाई है जो डेटा पुनर्प्राप्ति और अपडेट के निष्पादन के लिए जिम्मेदार है। यह खंड लेन-देन के बारे में विस्तार से बताता है।

लेन-देन बनाना

हम या तो कनेक्शन या EntityManage का उपयोग करके लेनदेन बना सकते हैं। नीचे दिए गए उदाहरण का उपयोग कनेक्शन बनाने और उसके अंदर डेटा को बचाने के लिए किया जाता है।

import {getConnection} from "typeorm"; 

await getConnection().transaction(async transactionalEntityManager => { 

   await connection.manager.save(students); 

});

EntityManager नीचे दिखाया गया है -

import {getManager} from "typeorm";

await getManager().transaction(async transactionalEntityManager => { 
   await transactionalEntityManager.save(students); 
});

सज्जाकार

हमारे पास TypeORM में तीन प्रकार के लेन-देन से संबंधित सज्जाकार हैं।

  • @Transaction - एकल डेटाबेस ट्रांसकेशन में सभी निष्पादन को लपेटता है।
  • @TransactionManager- लेन-देन के अंदर प्रश्नों को निष्पादित करने के लिए उपयोग किया जाता है। यह नीचे परिभाषित किया गया है,
@Transaction({ isolation: "SERIALIZABLE" }) 

save(@TransactionManager() manager: EntityManager, student: Student) {     
   return manager.save(student); 
}

यहाँ,

हमने इस्तेमाल किया SERIALIZABLE लेनदेन के लिए अलगाव स्तर।

  • @TransactionRepository- भंडार में लेनदेन को इंजेक्ट करने के लिए उपयोग किया जाता है। यह नीचे परिभाषित किया गया है,
@Transaction() save(student: Student, @TransactionRepository(Student) studentRepository: 
Repository<Student>) { 
   return studentRepository.save(student); 
}

QueryRunner में लेन-देन

सभी डेटाबेस क्वेरी को निष्पादित करने के लिए QueryRunner का उपयोग किया जाता है। इसका एकल डेटाबेस कनेक्शन है। डेटाबेस लेनदेन को QueryRunner का उपयोग करके आयोजित किया जा सकता है । आइए QueryRunner का उपयोग करके एकल लेनदेन करें ।

import {getConnection} from "typeorm"; 

// get a connection and create a new query runner 
const connection = getConnection(); const queryRunner = connection.createQueryRunner(); 

// establish real database connection using our new query runner 
await queryRunner.connect(); 

// now we can execute any queries on a query runner, for example: await queryRunner.query("SELECT * FROM students");

अब, नीचे दिए गए विवरण का उपयोग करके लेनदेन शुरू करें -

await queryRunner.startTransaction();

फिर, नीचे दिए गए कथन का उपयोग करके लेन-देन करें और रोलबैक करें,

try { 
   await queryRunner.commitTransaction(); 
}

यदि कोई त्रुटि है, तो इसे पकड़ () द्वारा नियंत्रित किया जाता है,

catch (err) { 

   // since we have errors lets rollback changes we made await queryRunner.rollbackTransaction(); 
}

अब, क्वेरीरनर को नीचे के रूप में जारी करें -

finally { 
   
   // you need to release query runner which is manually created: await queryRunner.release(); 
}

सामान्य रूप में, Indexingडेटा भंडारण का अनुकूलन करके एक डेटाबेस के प्रदर्शन का अनुकूलन करने के लिए एक प्रक्रिया है। इसका उपयोग डेटाबेस में डेटा को जल्दी से खोजने और एक्सेस करने के लिए किया जाता है। यह खंड टाइपफॉर्म में सूचकांक का उपयोग करने के तरीके के बारे में बताता है। संकेतों को विभिन्न प्रकारों में वर्गीकृत किया जाता है। आइए एक एक करके विस्तार से देखें।

कॉलम सूचकांकों

हम विशेष कॉलम का उपयोग करके सूचकांक बना सकते हैं @Indexग्राहक इकाई के एक उदाहरण पर विचार करें जैसा कि नीचे दिखाया गया है और सूचकांक के लिए परिभाषित किया गया हैfirstName स्तंभ,

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class Student { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Index() 
   @Column() 
   firstName: string; 
   
   @Column() 
   lastName: string; 
   
   @Column() 
   age: number; 
   
   @Column() 
   address: string; 
}

@Index एक इंडेक्स के लिए भी नाम निर्दिष्ट करने की अनुमति दें -

@Index("Name-idx") 
@Column() 
firstName: string;

अनोखा संकेत

अपने कॉलम में अद्वितीय अवरोधों को निर्दिष्ट करने के लिए , नीचे दी गई संपत्ति का उपयोग करें -

{ unique: true }

उदाहरण के लिए, नीचे नाम कॉलम के लिए अद्वितीय सूचकांक निर्दिष्ट करने के लिए कोड है -

@Index({ unique: true }) 
@Column() 
firstName: string;

एक से अधिक कॉलम के लिए सूचकांक लागू करने के लिए, हम सीधे @Eity () के बाद इसे निर्दिष्ट कर सकते हैं। नमूना कोड इस प्रकार है -

@Entity() 
@Index(["firstName", "lastName"]) @Index(["firstName", "lastName"], { unique: true })

स्थानिक सूचकांक

स्थानिक सूचकांक स्थानिक वस्तुओं तक पहुंचने की अनुमति देता है। MySQL और PostgreSQL spacial सूचकांकों का समर्थन करता है। अपने कॉलम में स्थानिक सूचकांक सक्षम करने के लिए, निम्नलिखित संपत्ति जोड़ें -

{ spatial: true }

स्थानिक प्रकार के कई उप प्रकार होते हैं जैसे, ज्यामिति, बिंदु, लाइन स्ट्रिंग, बहुभुज आदि, उदाहरण के लिए, यदि आप अपने कॉलम में बिंदु स्थानिक प्रकार जोड़ना चाहते हैं, तो नीचे दिए गए कोड का उपयोग करें -

@Column("point") 
@Index({ spatial: true }) 
point: string;

सिंक्रनाइज़ेशन अक्षम करें

सिंक्रनाइज़ेशन को अक्षम करने के लिए, नीचे दिए गए विकल्प का उपयोग करें @Index डेकोरेटर -

{ synchronize: false }

इकाई श्रोता उन संस्थाओं में उपयोग किया जाता है जो कस्टम विधि का समर्थन करते हैं और विशिष्ट घटनाओं को सुनते हैं। हम डेकोरेटर का उपयोग करके किसी भी इकाई कस्टम विधि को परिभाषित कर सकते हैं। चलिए सज्जाकारों को संक्षेप में समझते हैं।

  • @AfterLoad - जब QueryBuilder या रिपॉजिटरी / मैनेजर का उपयोग करके इकाई को लोड किया जाता है, तो यह विधि कहलाएगी।
  • @BeforeInsert - यह विधि रिपॉजिटरी / मैनेजर का उपयोग करके इकाई को सम्मिलित करने से पहले कॉल करेगी।
  • @AfterInsert - यह विधि रिपॉजिटरी / मैनेजर का उपयोग करके इकाई को सम्मिलित करने के बाद कॉल करेगी।
  • @BeforeUpdate - यह विधि किसी मौजूदा संस्था को रिपॉजिटरी / मैनेजर का उपयोग करके अपडेट करने से पहले कॉल करेगी।
  • @AfterUpdate - यह एक इकाई के अद्यतन होने के बाद कॉल करेगा।
  • @BeforeRemove - यह एक इकाई को हटाने से पहले कॉल करेगा।
  • @AfterRemove - यह एक इकाई को हटाने के बाद कॉल करेगा।

ग्राहक

सब्सक्राइबर का उपयोग विशिष्ट इकाई घटनाओं को सुनने के लिए किया जाता है। से लागू किया जाता हैEntitySubscriberInterface। आइए सब्सक्राइबर में यूनिट श्रोता का उपयोग कैसे करें, इसके लिए एक सरल उदाहरण को समझते हैं। विचार करें कि छात्र इकाई नीचे दी गई है -

Student.ts

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class Student {     

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   Name: string; 
   
   @Column() 
   age: number; 
}

छात्र ग्राहक बनाएं

सब्सक्राइबर नीचे कमांड का उपयोग करके बनाया गया है -

typeorm subscriber:create -n StudentSubscriber

उपरोक्त कमांड आपके प्रोजेक्ट src के अंदर एक ग्राहक निर्देशिका बनाता है। फिर, StudentSubscriber.ts फ़ाइल आपके ग्राहक के अंदर बनाई गई है। आप निम्न प्रतिक्रिया देख सकते हैं,

Subscriber /Users/workspace/TypeORM/FirstProject/src/subscriber/StudentSubscriber.ts has been created successfully.

अब फ़ाइल पर जाएँ, आप नीचे कोडिंग देख सकते हैं -

StudentSubscriber.ts

import {EventSubscriber, EntitySubscriberInterface} from "typeorm"; 

@EventSubscriber() 
export class StudentSubscriber implements EntitySubscriberInterface<any> { 
}

अब, फ़ाइल में निम्न परिवर्तन जोड़ें,

import {EventSubscriber, EntitySubscriberInterface,InsertEvent} from "typeorm"; 
import {Student} from "../entity/Student"; 

@EventSubscriber() 
export class StudentSubscriber implements EntitySubscriberInterface<any> { 
   listenTo() 
   { 
      return Student; 
   } 
   
   afterInsert(event: InsertEvent<Student>) { 
      console.log(event); 
   } 
}

यहाँ,

हमने इस्तेमाल किया है afterInsert()इकाई घटना को कॉल करने की विधि। इसी तरह, आप अन्य घटनाओं का भी उपयोग कर सकते हैं। हमने ormconfig.json फ़ाइल पहले ही कॉन्फ़िगर कर ली है। अब, नीचे दिए गए परिवर्तनों को इसमें जोड़ेंindex.ts फाइल इस प्रकार है -

index.ts

import "reflect-metadata"; import {createConnection} from "typeorm"; import {Student} from "./entity/Student"; 

createConnection().then(async connection => {

   console.log('connection established'); 
}).catch(error => console.log(error));

एप्लिकेशन को निष्पादित करने के बाद, आप अपनी स्क्रीन पर निम्न आउटपुट देख सकते हैं,

लॉगिंग

डेटाबेस लॉगिंग आपके अत्यधिक उपलब्ध डेटाबेस सॉल्यूशन डिज़ाइन का एक महत्वपूर्ण हिस्सा है क्योंकि डेटाबेस लॉग एक विफलता से उबरना संभव बनाते हैं, और वे प्राथमिक और माध्यमिक डेटाबेस को सिंक्रनाइज़ करना संभव बनाते हैं।

सभी डेटाबेस में उनके साथ जुड़े लॉग होते हैं। ये लॉग डेटाबेस परिवर्तन का रिकॉर्ड रखते हैं। यदि किसी डेटाबेस को अंतिम पूर्ण, ऑफ-लाइन बैकअप से परे एक बिंदु पर पुनर्स्थापित करने की आवश्यकता होती है, तो डेटा को विफलता के बिंदु तक आगे ले जाने के लिए लॉग की आवश्यकता होती है।

लॉगिंग विकल्प

डेटाबेस कनेक्शन में {लॉगिंग: ट्रू} को जोड़कर लॉगिंग को सक्षम किया गया है। लॉगिंग विकल्पों को विभिन्न प्रकारों में वर्गीकृत किया गया है। वे इस प्रकार हैं -

query- सभी लॉग क्वेरी वापस करें। इसे नीचे दिए गए अनुसार परिभाषित किया गया है -

{ 
   host: "localhost",
   ... 
   logging: ["query"] 
}

error- सभी विफल प्रश्नों और त्रुटियों के लिए रिटर्न लॉग। यह नीचे परिभाषित किया गया है -

{ 
   host: "localhost",
   ... 
   logging: ["error"] 
}

schema - स्कीमा के लिए लॉग लॉग।

warn - आंतरिक ORM चेतावनी लौटाएं।

info - रिटर्न आंतरिक ORM सूचनात्मक संदेश लॉग करता है।

log - आंतरिक ORM लॉग संदेश लौटाएं।

कस्टम लकड़हारा

कस्टम लॉगिंग सरल और उच्च अनुकूलन लॉगिंग विकल्प है। हम नीचे दिए गए कोड का उपयोग करके अपना स्वयं का लकड़हारा वर्ग बना सकते हैं -

import {Logger} from "typeorm"; 

export class MyCustomLogger implements Logger { 
   
   // implement all methods from logger class 
}

कनेक्शन का विकल्प ormconfig.json में निर्दिष्ट है -

name: "mysql", 
type: "mysql", 
host: "localhost", 
port: 3306, 
username: "root", 
password: "root", 
database: "test", 
logger: new MyCustomLogger()

द्वारा समर्थित डिफ़ॉल्ट भाषा TypeORM है TypeScript। चूंकि, टाइपस्क्रिप्ट स्थैतिक टाइपिंग, कक्षाओं और सज्जाकार का समर्थन करता है, इसलिए इकाई और इसकी विशेषताओं को परिभाषित करना आसान है। एक ही समय पर,JavaScript आवश्यक के रूप में अच्छी तरह से परियोजना में जहां पसंदीदा भाषा जावास्क्रिप्ट है। TypeORMजावास्क्रिप्ट भाषा के लिए भी पूर्ण समर्थन प्रदान करता है। टाइप करें जावास्क्रिप्ट के es5 और es6 दोनों प्रकारों का समर्थन करता है।

इस अध्याय में, हम सीखते हैं कि जावास्क्रिप्ट ES5 (ECMAScript 5) में टाइपफॉर्म एप्लिकेशन कैसे लिखें।

कमांड प्रॉम्प्ट खोलें और अपने कार्यक्षेत्र पर जाएं।

cd /path/to/workspace/

एक टाइप प्रोजेक्ट बनाने के लिए कमांड के नीचे चलाएँ।

typeorm init --name typeorm-javascript-student-app --database mysql

खुला हुआ package.json फ़ाइल प्रकार संदर्भ को निकालने के लिए।

मूल

{ 
   "name": "typeorm-javascript-student-app", "version": "0.0.1", 
   "description": "Awesome project developed with TypeORM.", "devDependencies": { 
      "ts-node": "3.3.0", "@types/node": "^8.0.29", "typescript": "3.3.3333" 
   }, 
   "dependencies": { 
      "typeorm": "0.2.24", "reflect-metadata": "^0.1.10", "mysql": "^2.14.1" 
   }, 
   "scripts": { 
      "start": "ts-node src/index.ts" } 
}

अद्यतन

{ 
   "name": "typeorm-javascript-student-app", "version": "0.0.1", 
   "description": "Awesome project developed with TypeORM.", "dependencies": { 
      "typeorm": "0.2.24",
      "mysql": "^2.14.1" 
   }, 
   "scripts": { 
   "start": "node src/index.js" 
   } 
}

यहाँ,

  • निकाला गया devDependencies अनुभाग और टाइपस्क्रिप्ट संबंधित पैकेज में dependences अनुभाग।
  • टाइपस्क्रिप्ट कोड के बजाय जावास्क्रिप्ट कोड को इंगित करने के लिए प्रारंभ स्क्रिप्ट को बदल दिया।

आवश्यक पैकेज स्थापित करने के लिए कमांड के नीचे चलाएँ।

npm install

हटाना tsconfig.json और index.ts फ़ाइल।

निकाय फ़ोल्डर के अंदर User.ts फ़ाइल निकालें और फिर json प्रारूप में छात्र इकाई बनाएँ, student.json जैसा कि नीचे दिया गया है -

{ 
   "name": "Student", 
   "columns": { 
      "id": { 
         "primary": true, 
         "type": "int", 
         "generated": true 
      }, 
      "name": { 
         "type": "varchar" 
      }, 
      "age": { 
         "type": "integer" 
      } 
   } 
}

एक नई फ़ाइल बनाएँ, src / index.js और नीचे दिया गया कोड डालें -

var typeorm = require("typeorm"); var EntitySchema = typeorm.EntitySchema; 

typeorm.createConnection({ 
   "type": "mysql", 
   "host": "localhost", 
   "port": 3306, 
   "username": "root", 
   "password": "123456", 
   "database": "typeorm_test_db",
   "synchronize": true, 
   "logging": false, 
   entities: [ new EntitySchema(require("./entity/student.json")) 
   ] 
}) 
.then(function(connection) { 
   return connection.getRepository("Student"); }) .then(function(studentRepository) { 
   var student = { 
      name: "Student1", 
      age: 18 
   }; 
   return studentRepository.save(student) .then(function(savedStudent) { console.log("Student has been successfully saved: ", savedStudent); 
   return studentRepository.find(); }) 
   .then(function(students) { console.log("All students: ", students); 
   return; 
   }) 
   .catch(function(error) { console.log("Error: ", error); return; 
   }) 
}) 
.catch(function(error) { console.log("Error: ", error) 
   return; });

यहाँ,

हमने नीचे उल्लिखित परिवर्तनों को छोड़कर समान प्रकार की विधियों का उपयोग किया है,

  • उपयोग किया गया EntitySchema छात्र इकाई को कॉन्फ़िगर करने के लिए।
  • प्रयुक्त जावास्क्रिप्ट वादा अवधारणा (तब / पकड़ / अंत में) ब्लॉक।

अब, नीचे दिए गए कमांड का उपयोग करके एप्लिकेशन चलाएं -

npm start

आवेदन डेटाबेस में छात्र की जानकारी सम्मिलित करता है और फिर डेटाबेस में सभी छात्रों को लाने और नीचे दिखाए अनुसार कंसोल में दिखाएगा -

> [email protected] start /path/to/workspace/typeorm-javascript-student-app

> node src/index.js 

Student has been successfully saved: { name: 'Student1', age: 18, id: 1 } All students: [ { id: 1, name: 'Student1', age: 18 } ]

यह अध्याय टाइपम द्वारा प्रदान किए गए व्यापक MongoDB डेटाबेस समर्थन की व्याख्या करता है। उम्मीद है, हम npm का उपयोग कर mongodb स्थापित किया है। यदि यह स्थापित नहीं है, तो MongoDB ड्राइवर को स्थापित करने के लिए नीचे दिए गए कमांड का उपयोग करें,

npm install mongodb --save

एक परियोजना का निर्माण

चलिए MongoDB का उपयोग करके एक नई परियोजना बनाते हैं: -

typeorm init --name MyProject --database mongodb

Ormconfig.json कॉन्फ़िगर करें

चलो नीचे निर्दिष्ट के रूप में ormconfig.json फ़ाइल में MongoDB होस्ट, पोर्ट और डेटाबेस विकल्प कॉन्फ़िगर करें -

ormconfig.json

{ 
   "type": "mongodb", 
   "host": "localhost", 
   "port": 27017, 
   "database": "test", 
   "synchronize": true, 
   "logging": false, 
   "entities": [ 
      "src/entity/**/*.ts" 
   ], 
   "migrations": [ "src/migration/**/*.ts" 
   ], 
   "subscribers": [ "src/subscriber/**/*.ts" 
   ], 
   "cli": { 
      "entitiesDir": "src/entity", "migrationsDir": "src/migration", "subscribersDir": "src/subscriber" 
   } 
}

संस्थाओं और स्तंभों को परिभाषित करें

अपनी src डायरेक्टरी के अंदर स्टूडेंट नाम की एक नई संस्था बनाते हैं। एंटिटी और कॉलम समान हैं। प्राथमिक कुंजी स्तंभ उत्पन्न करने के लिए, हम उपयोग करते हैं@PrimaryColumn या

@PrimaryGeneratedColumn. इसे इस रूप में परिभाषित किया जा सकता है @ObjectIdColumn. सरल उदाहरण नीचे दिखाया गया है -

Student.ts

import {Entity, ObjectID, ObjectIdColumn, Column} from "typeorm"; 

@Entity() 
export class Student {  

   @ObjectIdColumn() 
   id: ObjectID; 
   
   @Column() 
   Name: string; 
   
   @Column() 
   Country: string; 
}

इस इकाई को बचाने के लिए, index.ts फ़ाइल खोलें और निम्नलिखित परिवर्तन जोड़ें -

index.ts

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import {Student} from "./entity/Student"; 

createConnection().then(async connection => { 

   console.log("Inserting a new Student into the database..."); const std = new Student(); std.Name = "Student1"; 
   std.Country = "India"; 
   await connection.manager.save(std); console.log("Saved a new user with id: " + std.id); 
   
   console.log("Loading users from the database..."); 
   const stds = await connection.manager.find(Student); console.log("Loaded users: ", stds); 
   
   console.log("TypeORM with MongoDB"); 
}).catch(error => console.log(error));

अब, अपना सर्वर शुरू करें और आपको निम्न प्रतिक्रिया मिलेगी -

npm start

MongoDB EntityManager

हम डेटा लाने के लिए EntityManager का भी उपयोग कर सकते हैं। सरल उदाहरण नीचे दिखाया गया है -

import {getManager} from "typeorm";

const manager = getManager(); 
const result = await manager.findOne(Student, { id:1 });

इसी तरह, हम डेटा तक पहुंचने के लिए रिपॉजिटरी का भी उपयोग कर सकते हैं।

import {getMongoRepository} from "typeorm"; 

const studentRepository = getMongoRepository(Student); 
const result = await studentRepository.findOne({ id:1 });

यदि आप निम्न प्रकार से समान विकल्प का उपयोग करके डेटा को फ़िल्टर करना चाहते हैं -

import {getMongoRepository} from "typeorm"; 

const studentRepository = getMongoRepository(Student); 
const result = await studentRepository.find({ 
   where: { 
      Name: {$eq: "Student1"}, 
   } 
});

जैसा कि हमने इस अध्याय में देखा, टाइप करें MongoDB डेटाबेस इंजन के साथ काम करना आसान बनाता है।

वेब एप्लिकेशन बनाने के लिए एक्सप्रेस लोकप्रिय जावास्क्रिप्ट ढांचे में से एक है। आइए जानें कैसे इस्तेमाल करेंTypeORM इस अध्याय में व्यक्त रूपरेखा के साथ।

एक सरल अनुप्रयोग बनाना

TypeORM CLI एक पूर्ण कार्य एक्सप्रेस वेब एप्लिकेशन (रेस्टेबल एपीआई एप्लिकेशन) के साथ एकीकृत करने के लिए एक आसान विकल्प प्रदान करता है TypeORM। एप्लिकेशन बनाने के लिए CLI कमांड निम्नानुसार है -

cd /path/to/workspace typeorm init --express --name typeorm-express-sample --database mysql

ऊपर कमांड टाइपोर्म-एक्सप्रेस-सैंपल फ़ोल्डर के तहत एक नया वेब एप्लिकेशन बनाएगा। आवेदन की संरचना इस प्रकार है -

│ .gitignore 
│ ormconfig.json 
│ package.json 
│ README.md 
│ tsconfig.json 
│ └───src 
      │ index.ts 
      │ routes.ts 
      │ 
      ├───controller 
      │      UserController.ts 
      │ 
      ├───entity 
      │      User.ts 
      │ 
      └───migration

यहाँ,

जैसा कि हम जानते हैं, ormconfig.json है TypeORMविन्यास फाइल। कोड निम्नानुसार है,

{ 
   "type": "mysql", 
   "host": "localhost", 
   "port": 3306, 
   "username": "test", 
   "password": "test", 
   "database": "test", 
   "synchronize": true, 
   "logging": false, 
   "entities": [
      "src/entity/**/*.ts" 
   ], 
   "migrations": [ "src/migration/**/*.ts" 
   ], 
   "subscribers": [ "src/subscriber/**/*.ts" 
   ], 
   "cli": { 
      "entitiesDir": "src/entity", "migrationsDir": "src/migration", "subscribersDir": "src/subscriber" 
   } 
}

यहां, अपने स्थानीय डेटाबेस सेटिंग से मिलान करने के लिए डेटाबेस सेटिंग बदलें।

package.json फ़ाइल अनुप्रयोग का मुख्य विन्यास है।

tsconfig.json फ़ाइल में टाइपस्क्रिप्ट से संबंधित कॉन्फ़िगरेशन है।

entity फ़ोल्डर में है TypeORMमॉडल। एक डिफ़ॉल्ट उपयोगकर्ता मॉडल सीएलआई द्वारा बनाया जाएगा और यह इस प्रकार है -

import {Entity, PrimaryGeneratedColumn, Column} from "typeorm"; 

@Entity() 
export class User { 
   
   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   firstName: string; 
   
   @Column() 
   lastName: string; 
   
   @Column() 
   age: number; 
}

controllerफ़ोल्डर में एक्सप्रेस नियंत्रक होते हैं। CLI उपयोगकर्ता विवरण जोड़ने / सूची / हटाने के साथ एक डिफ़ॉल्ट उपयोगकर्ता एपीआई नियंत्रक बनाते हैं। कोड इस प्रकार है -

import {getRepository} from "typeorm"; import {NextFunction, Request, Response} from "express"; import {User} from "../entity/User"; 

export class UserController {

   private userRepository = getRepository(User); 
   
   async all(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.find(); 
   } 
   
   async one(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.findOne(request.params.id); 
   } 
   
   async save(request: Request, response: Response, next: NextFunction) { 
      return this.userRepository.save(request.body); 
   } 
   
   async remove(request: Request, response: Response, next: NextFunction) { 
      let userToRemove = await this.userRepository.findOne(request.params.id); 
      await this.userRepository.remove(userToRemove); 
   } 
}

यहाँ,

all डेटाबेस से सभी उपयोगकर्ताओं को लाने के लिए विधि का उपयोग किया जाता है।

one विधि का उपयोग डेटाबेस से एक उपयोगकर्ता को लाने के लिए किया जाता है user id

save डेटाबेस में उपयोगकर्ता की जानकारी को बचाने के लिए विधि का उपयोग किया जाता है।

delete विधि का उपयोग उपयोगकर्ता को डेटाबेस से हटाने के लिए किया जाता है user id

routes.ts फाइल यूजर यूजर मेथड के तरीके को उचित URL और कोड निम्नानुसार है -

import {UserController} from "./controller/UserController"; 

export const Routes = [{ 
      method: "get", 
      route: "/users", 
      controller: UserController, action: "all" 
   }, { 
      method: "get", 
      route: "/users/:id", controller: UserController, action: "one" 
   }, { 
      method: "post", 
      route: "/users", 
      controller: UserController, action: "save" 
   }, { 
      method: "delete", route: "/users/:id", controller: UserController,
      action: "remove" 
}];

यहाँ,

/ user url को यूजर कंट्रोलर को मैप किया जाता है। प्रत्येक क्रिया पोस्ट, विभिन्न तरीकों से मैप और डिलीट की जाती है।

आखिरकार, index.tsहमारा मुख्य वेब एप्लीकेशन एंट्री पॉइंट है। स्रोत कोड इस प्रकार है -

import "reflect-metadata"; 
import {createConnection} from "typeorm"; 
import * as express from "express"; import * as bodyParser from "body-parser"; 
import {Request, Response} from "express"; 
import {Routes} from "./routes"; import {User} from "./entity/User"; 

createConnection().then(async connection => { 

   // create express app const app = express(); app.use(bodyParser.json()); 

   // register express routes from defined application routes Routes.forEach(route => { 
      (app as any)[route.method](route.route, (req:   Request, res: Response, next: Function) => { 
         const result = (new (route.controller as any))[route.action](req, res, next); 
         if (result instanceof Promise) { 
            result.then(result => result !== null && result !== undefined ? res.send(result) : undefined); 
         } else if (result !== null && result !== undefined) { 
            .json(result); 
         } 
      }); 
   }); 
      
   // setup express app here 
   // ... 
      
   // start express server app.listen(3000); 
      
   // insert new users for test await connection.manager.save(connection.manager.create(User, { 
      firstName: "Timber",
      lastName: "Saw", 
      age: 27 
   }));
   await connection.manager.save(connection.manager.create(User, { 
      firstName: "Phantom", 
      lastName: "Assassin", 
      age: 24 
   })); 
      
   console.log("Express server has started on port 3000. Open http://localhost:3000/users to see results"); 
}).catch(error => console.log(error));

यहां, एप्लिकेशन मार्गों को कॉन्फ़िगर करता है, दो उपयोगकर्ताओं को सम्मिलित करता है और फिर पोर्ट 3000 पर वेब एप्लिकेशन शुरू करता है । हम इस एप्लिकेशन को एक्सेस कर सकते हैंhttp://localhost:3000

एप्लिकेशन को चलाने के लिए, नीचे दिए गए चरणों का पालन करें -

आइए नीचे दिए गए कमांड का उपयोग करके आवश्यक पैकेज स्थापित करें -

npm install

उत्पादन

npm notice created a lockfile as package-lock.json. You should commit this file. 
npm WARN [email protected] No repository field. 
npm WARN [email protected] No license field. 

added 176 packages from 472 contributors and audited 351 packages in 11.965s 

3 packages are looking for funding  run `npm fund` for details 

found 0 vulnerabilities

एप्लिकेशन शुरू करने के लिए नीचे दिया गया कमांड चलाएँ।

npm start

उत्पादन

> [email protected] start /path/to/workspace/typeorm-express-sample 
> ts-node src/index.ts 

Express server has started on port 3000. Open http://localhost:3000/users to see results

आइए नीचे दिए गए कर्ल कमांड का उपयोग करके अपने वेब एप्लिकेशन एपीआई तक पहुँचें -

curl http://localhost:3000/users

यहाँ,

curl कमांड प्रॉम्प्ट से वेब एप्लिकेशन को एक्सेस करने के लिए एक कमांड लाइन एप्लिकेशन है। यह सभी HTTP वर्ब्स जैसे गेट, पोस्ट, डिलीट, आदि को सपोर्ट करता है।

उत्पादन

[{"id":1,"firstName":"Timber","lastName":"Saw","age":27},{"id":2,"firstName":"Phantom","lastName":"Assassin","age":24}]

पहला रिकॉर्ड लाने के लिए, हम नीचे कमांड का उपयोग कर सकते हैं -

curl http://localhost:3000/users/1

उत्पादन

{"id":1,"firstName":"Timber","lastName":"Saw","age":27}

उपयोगकर्ता रिकॉर्ड को हटाने के लिए, हम नीचे कमांड का उपयोग कर सकते हैं -

curl -X DELETE http://localhost:3000/users/1

जैसा कि हमने इस अध्याय में देखा, TypeORM आसानी से एक्सप्रेस आवेदन में एकीकृत किया जा सकता है।

माइग्रेशन आपके डेटाबेस के लिए संस्करण नियंत्रण की तरह हैं। इसका उपयोग एप्लिकेशन के डेटाबेस स्कीमा को संशोधित करने और साझा करने के लिए किया जाता है। यह खंड इस बात की व्याख्या करता है कि टाइपफॉर्म में माइग्रेशन कैसे काम करता है।

नया प्रवास बनाना

एक नया माइग्रेशन बनाने के लिए, पहले हमें ormconfig.json में कनेक्शन सेटअप करना होगा। यह नीचे परिभाषित किया गया है -

ormconfig.json

"type": "mysql", 
"host": "localhost", 
"port": 8889, 
"username": "root", 
"password": "root", 
"database": "Library", 
"entities": ["entity/*.js"], "migrationsTableName": "student_migration_table", "migrations": ["migration/*.js"], "cli": { 
   "migrationsDir": "migration" 
}

यहाँ,

  • migrationsTableName - यह माइग्रेशन टेबल नाम को संदर्भित करता है।
  • migrations - दिए गए डायरेक्टरी से टाइप लोड माइग्रेशन।
  • cli - इंगित करता है कि माइग्रेशन विशिष्ट निर्देशिका के अंदर बनाएगा।

पुस्तक इकाई बनाएँ

नाम से एक इकाई बनाते हैं Book इकाई अंदर src/entity/Book.ts निम्नानुसार है -

import { Entity, Column, PrimaryGeneratedColumn } from 'typeorm'; 
@Entity() 
export class Book { 

   @PrimaryGeneratedColumn() 
   id: number; 
   
   @Column() 
   title: string;
   
   @Column() 
   text: string; 
}

नया माइग्रेशन बनाने के लिए CLI निष्पादित करें

अब, हम सीएलआई का उपयोग करके नए माइग्रेशन को निष्पादित कर सकते हैं -

वाक्य - विन्यास

typeorm migration:create -n <migration-name>

उदाहरण

typeorm migration:create -n myMigration

उपरोक्त कमांड निष्पादित करने के बाद, आप नीचे दी गई प्रतिक्रिया देख सकते हैं -

Migration /path/to/project/src/migration/1587101104904-myMigration.ts has been generated successfully.

अब, अंदर चलो src/migration/1587101104904-myMigration.ts फ़ाइल इसके समान दिखाई देती है।

import {MigrationInterface, QueryRunner} from "typeorm"; 

export class myMigration1587101104904 implements MigrationInterface {      

   public async up(queryRunner: QueryRunner): Promise<any> { 
   } 
   
   public async down(queryRunner: QueryRunner): Promise<any> { 
   } 
}

यहाँ,

हमारे पास दो तरीके हैं up तथा downup पद्धति का उपयोग माइग्रेशन में परिवर्तन और जोड़ने के लिए किया जाता है down आपके माइग्रेशन में हुए परिवर्तनों को वापस लाने के लिए विधि का उपयोग किया जाता है।

हमें जोड़ते हैं up अंदर की विधि myMigration.ts नीचे बताए अनुसार फाइल करें -

import {MigrationInterface, QueryRunner} from "typeorm"; 

export class Book1587131893261 implements MigrationInterface { 

   public async up(queryRunner: QueryRunner): Promise<any> { 
      await queryRunner.query(`ALTER TABLE book ADD COLUMN price int`); 
   }
   public async down(queryRunner: QueryRunner): Promise<any> { } 
}

यहाँ,

हमने एक नया कॉलम जोड़ा है price के भीतर bookतालिका। अब, उपरोक्त परिवर्तनों को जोड़ने के लिए CLI निष्पादित करें।

ts-node ./node_modules/typeorm/cli.js migration:run

उपरोक्त कमांड माइग्रेशन निष्पादित करता है और उन्हें एक क्रम में चलाता है। अब, आप अपनी स्क्रीन में नीचे परिवर्तन देख सकते हैं -

उत्पादन

अब अपना mysql सर्वर खोलें, नया कॉलम जोड़ा गया है। यह नीचे दिखाया गया है -

इसी प्रकार, हम कॉलम शीर्षक डेटाटाइप को varchar (30) में निम्नानुसार संशोधित कर सकते हैं,

import {MigrationInterface, QueryRunner} from "typeorm"; 

export class Book1587131893261 implements MigrationInterface { 

   public async up(queryRunner: QueryRunner): Promise<any> { 
   await queryRunner.query(`ALTER TABLE book MODIFY COLUMN title varchar(30)`); 
      } 
   public async down(queryRunner: QueryRunner): Promise<any> { 
   } 
}

अब, उसी कमांड को निष्पादित करें और आप नीचे किए गए परिवर्तन कर सकते हैं -

ts-node ./node_modules/typeorm/cli.js migration:run

उत्पादन

Book तालिका के रूप में संशोधित किया गया है,

माइग्रेशन वापस करें

चलिए नीचे दिए गए कोड को अंदर जोड़ते हैं down प्रवासन वापस करने की विधि -

import {MigrationInterface, QueryRunner} from "typeorm"; 

export class Book1587131893261 implements MigrationInterface { 
   
   public async up(queryRunner: QueryRunner): Promise<any> { 
   
   } 
   public async down(queryRunner: QueryRunner): Promise<any> { 
   
      await queryRunner.query(`ALTER TABLE book drop column price`); // reverts things made in "up" method
   } 
}

अब, सभी परिवर्तनों को वापस करने के लिए नीचे दिए गए आदेश को निष्पादित करें -

ts-node ./node_modules/typeorm/cli.js migration:revert

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

उत्पादन

Book तालिका के रूप में संशोधित किया गया है,

उत्पादन

जैसा कि हमने इस अध्याय में देखा, TypeORM डेटाबेस माइग्रेशन स्क्रिप्ट लिखना आसान बनाता है।

यह खंड टाइप सीएलआई कमांड के बारे में विस्तार से बताता है।

टाइप प्रोजेक्ट बनाएं

typeorm initएक टाइप प्रोजेक्ट को सेटअप करने का सबसे आसान और तेज़ तरीका है। आप एक नया प्रोजेक्ट बना सकते हैं,

typeorm init --name Demoproject --database mysql

कमांड निष्पादित करने के बाद, आपको अपनी स्क्रीन पर निम्न आउटपुट मिलेंगे -

Project created inside /Users/workspace/TypeORM/Demoproject directory.

एक इकाई बनाएँ

CLI का उपयोग करके एक नई इकाई बनाने के लिए,

typeorm entity:create -n Person

अब, व्यक्ति इकाई आपकी परियोजना src निर्देशिका के अंदर बनाई गई है।

Entity /Users/workspace/TypeORM/Demoproject/src/entity/Person.ts has been created successfully.

यदि आपके पास अलग-अलग निर्देशिकाओं में कई संस्थाओं के साथ एक मल्टी-मॉड्यूल प्रोजेक्ट संरचना है, तो आप नीचे दिए गए कमांड का उपयोग कर सकते हैं,

typeorm entity:create -n Person -d src/Person/entity

एक नया ग्राहक बनाएं

सीएलआई का उपयोग कर एक नया ग्राहक बनाने के लिए निम्नानुसार है -

typeorm subscriber:create -n PersonSubscriber

आप निम्नलिखित प्रतिक्रिया देख सकते हैं -

Subscriber /path/to/TypeORM/Demoproject/src/subscriber/PersonSubscriber.ts has been created successfully.

पलायन पैदा करते हैं

आप नीचे बताए अनुसार CLI का उपयोग करके एक नया माइग्रेशन बना सकते हैं -

typeorm migration:create -n PersonMigration

उपरोक्त कमांड ने आपके प्रोजेक्ट src के अंदर एक माइग्रेशन डायरेक्टरी बनाई। माइग्रेशन फ़ाइलें इसके अंदर संग्रहीत की जाती हैं।

Migration /path/to/TypeORM/Demoproject/src/migration/1587395030750-PersonMigration.ts has been generated successfully.

डेटाबेस स्कीमा

डेटाबेस स्कीमा को सिंक्रनाइज़ करने के लिए, नीचे दिए गए कमांड का उपयोग करें -

typeorm schema:sync

डेटाबेस स्कीमा को पूरी तरह से छोड़ने के लिए, नीचे दिए गए कमांड का उपयोग करें -

typeorm schema:drop

Sql प्रश्न

यदि आप किसी भी एसक्यूएल प्रश्नों को निष्पादित करना चाहते हैं, तो हम यहां से सीधे निष्पादित कर सकते हैं। उदाहरण के लिए, ग्राहकों के सभी रिकॉर्ड प्रदर्शित करने के लिए, नीचे दिए गए क्वेरी का उपयोग करें -

typeorm query "select * from customers"

यदि आप कैश में संग्रहित सब कुछ साफ़ करना चाहते हैं। आप इसे निम्न कमांड का उपयोग करके कर सकते हैं -

typeorm cache:clear

निष्कर्ष

टाइपफॉर्म कई डेटाबेस के साथ छोटे पैमाने के अनुप्रयोगों से बड़े पैमाने पर उद्यम अनुप्रयोगों के लिए उच्च गुणवत्ता और स्केलेबल एप्लिकेशन बनाने के लिए एक उत्कृष्ट खुला स्रोत ओआरएम फ्रेमवर्क है।