Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

कोडनिर्देशक लेनदेन

transactions का उपयोग करना इसका अर्थ है डेटा को सुरक्षित रूप से सम्मिलित करने के लिए डेटाबेस का समर्थन करना। इसलिए कोडनिर्देशक में हम मॉडल . में प्रत्येक डेटाबेस से संबंधित कार्यों को लिखते हैं नियंत्रक में नहीं। . और आपके दूसरे कोड में (जो काम नहीं कर रहा है) आपने वहां पर मॉडल की ओर इशारा किया है।(utils ) इतना आसान मुझे यकीन है कि यह काम नहीं करेगा। क्योंकि यह मॉडल और नियंत्रक समानांतर के साथ एक सम्मिलित डेटा नहीं है। लेन-देन को मॉडल में कोडित किया जाना चाहिए (मैं अपने उत्तर में मॉडल में लिखूंगा )।

इस सामग्री को भी लोड करें

  1. डेटाबेस लाइब्रेरी
  2. मॉडल क्लास
  3. यूआरएल सहायक
  4. सत्र

मान्यताएं

अपने कोड में आपने $data . का इस्तेमाल किया है और $test सरणी के रूप में। तो मुझे लगता है कि डेटा डालने और अपडेट करने के लिए दो सरणी हैं।

आपके डेटा सेट

$data = array(
   'title' => 'My title' ,
   'name' => 'My Name' ,
   'date' => 'My date'
);

$id = 007;
$test = array(
   'title' => $title,
   'name' => $name,
   'date' => $date
);

आपका कोड

$this->db->trans_start(); # Starting Transaction
$this->db->trans_strict(FALSE); # See Note 01. If you wish can remove as well 

$this->db->insert('table_name', $data); # Inserting data

# Updating data
$this->db->where('id', $id);
$this->db->update('table_name', $test); 

$this->db->trans_complete(); # Completing transaction

/*Optional*/

if ($this->db->trans_status() === FALSE) {
    # Something went wrong.
    $this->db->trans_rollback();
    return FALSE;
} 
else {
    # Everything is Perfect. 
    # Committing data to the database.
    $this->db->trans_commit();
    return TRUE;
}

नोट

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


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. तालिका को दो बार निर्दिष्ट किया गया है, दोनों 'अद्यतन' के लिए लक्ष्य के रूप में और mysql में डेटा के लिए एक अलग स्रोत के रूप में

  2. डेटाबेस फ़ील्ड को 1 . से बढ़ाएँ

  3. mysql तैयार कथन त्रुटि:MySQLSyntaxErrorException

  4. मॉनिटरिंग Percona XtraDB क्लस्टर - प्रमुख मेट्रिक्स

  5. दो तिथियों के बीच की तिथियों की सूची प्राप्त करें