टाइप - क्वेरी बिल्डर

क्वेरी बिल्डर का उपयोग आसान तरीके से जटिल SQL क्वेरी बनाने में किया जाता है। इसे कनेक्शन विधि और 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();