>데이터 베이스 >MySQL 튜토리얼 >CodeIgniter 활성 레코드에서 삽입 작업 후 마지막 자동 증가 ID를 검색하는 방법은 무엇입니까?

CodeIgniter 활성 레코드에서 삽입 작업 후 마지막 자동 증가 ID를 검색하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-04 22:17:02864검색

How to Retrieve the Last Auto-Incremented ID After an Insert Operation in CodeIgniter Active Record?

CodeIgniter 활성 레코드로 마지막 자동 증가 ID 가져오기

질문:

귀하 CodeIgniter의 Active Record를 사용하여 삽입 작업을 수행한 후 마지막 자동 증가 ID를 검색하려고 시도했지만 모델의 add_post() 메서드가 빈 값을 반환합니다.

컨트롤러 내부:

<code class="php">function add_post(){
    $post_data = array(
        'id'            => '',
        'user_id'   =>  '11330',
        'content'   =>  $this->input->post('poster_textarea'),
        'date_time' => date("Y-m-d H:i:s"),
        'status'        =>  '1'
    );
    return $this->blog_model->add_post($post_data);
}</code>

모델 내부:

<code class="php">function add_post($post_data){
    $this->db->trans_start();
    $this->db->insert('posts',$post_data);
    $this->db->trans_complete();
    return $this->db->insert_id();
}</code>

답변:

문제는 다음 순서에 있습니다. 모델의 add_post() 메소드에서 작업을 수행합니다. 삽입 작업 후 마지막 자동 증가 ID를 올바르게 검색하려면 다음을 수행해야 합니다.

  1. $this->db->insert('posts', $post_data) 메소드.
  2. 그런 다음 $this->db->insert_id() 메소드를 사용하여 마지막으로 삽입된 ID를 검색합니다.
  3. 마지막으로 삽입된 ID를 결과로 반환합니다. add_post() 메소드.

해결책:

<code class="php">function add_post($post_data){
    $this->db->insert('posts', $post_data);
    $insert_id = $this->db->insert_id();

    return $insert_id;
}</code>

참고:

단일 트랜잭션에 여러 개의 삽입을 수행하는 경우 $this->db->trans_start() 및 $this->db->trans_complete() 메소드를 사용하여 트랜잭션을 시작하고 종료할 수 있습니다.

위 내용은 CodeIgniter 활성 레코드에서 삽입 작업 후 마지막 자동 증가 ID를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.