Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan ID Auto-Incremented Selepas Memasukkan Data dengan Rekod Aktif CodeIgniter?

Bagaimana untuk Mendapatkan ID Auto-Incremented Selepas Memasukkan Data dengan Rekod Aktif CodeIgniter?

Susan Sarandon
Lepaskan: 2024-11-04 21:24:02
asal
337 orang telah melayarinya

How to Get the Auto-Incremented ID After Inserting Data with CodeIgniter's Active Record?

Cara Mendapatkan ID Auto-Incremented selepas Pertanyaan Sisip dalam Rekod Aktif CodeIgniter

Apabila menggunakan perpustakaan Rekod Aktif CodeIgniter untuk operasi pangkalan data, anda mungkin perlu mendapatkan ID tambah automatik yang dimasukkan terakhir untuk operasi sisipan. Artikel ini meneroka cara yang mungkin untuk mencapai perkara ini.

Masalah

Dalam aplikasi CodeIgniter anda, anda cuba memasukkan data ke dalam jadual MySQL menggunakan kaedah sisipan() Active Record dalam sebuah model. Walau bagaimanapun, kod anda tidak mengembalikan ID dinaikkan automatik yang dijangkakan.

Penyelesaian

Untuk mendapatkan ID tambah automatik yang dimasukkan terakhir, ikut langkah berikut:

  1. Kemas kini model anda untuk melaksanakan operasi sisipan dahulu, kemudian dapatkan ID serta-merta selepas itu:
<code class="php">function add_post($post_data){
   $this->db->insert('posts', $post_data);
   $insert_id = $this->db->insert_id();

   return  $insert_id;
}</code>
Salin selepas log masuk
  1. Jika anda perlu melaksanakan berbilang sisipan dalam transaksi, kelilingi operasi dengan trans_start() dan trans_complete():
<code class="php">$this->db->trans_start();
$this->db->insert('posts', $post_data);
$insert_id = $this->db->insert_id();
$this->db->trans_complete();

return  $insert_id;</code>
Salin selepas log masuk

Pertimbangan Lanjut

  • Kaedah insert_id() CodeIgniter mengembalikan 0 jika sisipan tidak berjaya.
  • Jika jadual pangkalan data anda tidak mempunyai lajur penambahan automatik, insert_id() akan mengembalikan 0.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan ID Auto-Incremented Selepas Memasukkan Data dengan Rekod Aktif CodeIgniter?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan