प्रकार - लेन-देन
आम तौर पर, लेनदेन एक तर्क इकाई है जो डेटा पुनर्प्राप्ति और अपडेट के निष्पादन के लिए जिम्मेदार है। यह खंड लेन-देन के बारे में विस्तार से बताता है।
लेन-देन बनाना
हम या तो कनेक्शन या 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();
}