قد يتساءل المرء عن سبب عدم ارتكاب المعاملة أولاً وتراجعًا يدويًا في حالة حدوث خطأ. هذا النهج غير فعال لأنه يمكن أن يؤدي إلى إنشاء سجلات يتيمة أو عدم تناسق في قاعدة البيانات. يضمن حدوث التراجع إذا فشلت العمليات التالية. إليك كيفية تطور سير العمل:
tx, err := db.Begin() if err != nil { log.Fatal(err) } defer tx.Rollback() // Why defer?
]
البساطة: يؤدي تأجيل التراجع إلى تبسيط معالجة الخطأ ويضمن التناسق.
الموثوقية: ]
الكفاءة: يتجنب إنشاء سجلات Orphan أو عدم تناسق قاعدة البيانات في حالة الأخطاء.
لا يوجد تأثير على استدعاء tx.rollback () على معاملة ملتزمة ، حيث لا يمكن التراجع عن معاملة ملتزمة. ]
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3