CodeIgniter-데이터베이스 작업

다른 프레임 워크와 마찬가지로 우리는 데이터베이스와 매우 자주 상호 작용해야하며 CodeIgniter는이 작업을 쉽게 만듭니다. 데이터베이스와 상호 작용할 수있는 다양한 기능을 제공합니다.

이 섹션에서는 CRUD (생성, 읽기, 업데이트, 삭제) 기능이 CodeIgniter에서 작동하는 방식을 이해합니다. 우리는 사용할 것입니다stud 데이터를 선택, 업데이트, 삭제 및 삽입 할 테이블 stud 표.

테이블 이름 : 스터드
roll_no int (11)
이름 varchar (30)

데이터베이스에 연결

다음 두 가지 방법으로 데이터베이스에 연결할 수 있습니다.

  • Automatic Connecting− 자동 연결은 application / config / autoload.php 파일을 사용하여 수행 할 수 있습니다. 자동 연결은 각 페이지마다 데이터베이스를로드합니다. 아래와 같이 데이터베이스 라이브러리를 추가하면됩니다.

$autoload['libraries'] = array(‘database’);
  • Manual Connecting− 일부 페이지에만 데이터베이스 연결을 원할 경우 수동 연결을 할 수 있습니다. 클래스에 다음 줄을 추가하여 데이터베이스에 수동으로 연결할 수 있습니다.

$this->load->database();

여기에서는 모든 것이 데이터베이스 구성 파일 application / config / database.php에 설정되어 있으므로 인수를 전달하지 않습니다.

레코드 삽입

데이터베이스에 레코드를 삽입하려면 다음 표와 같이 insert () 함수가 사용됩니다.

Syntax

삽입 ([ $ table = '' [, $ set = NULL [, $ escape = NULL ]]])

Parameters

  • $table( 문자열 ) − 테이블 이름

  • $set( array ) − 필드 / 값 쌍의 연관 배열

  • $escape( bool ) − 값과 식별자를 이스케이프할지 여부

Returns

성공하면 TRUE, 실패하면 FALSE

Return Type

부울

다음 예제는 레코드를 삽입하는 방법을 보여줍니다. stud표. $ data는 데이터를 설정하고이 데이터를 테이블에 삽입하는 배열입니다.stud,이 배열을 두 번째 인수 의 삽입 함수에 전달하면됩니다 .

$data = array( 
   'roll_no' => ‘1’, 
   'name' => ‘Virat’ 
); 

$this->db->insert("stud", $data);

레코드 업데이트

데이터베이스의 레코드를 업데이트하려면 update() 기능은 함께 사용됩니다 set()where()아래 표에 표시된 기능. 그만큼set() 기능은 업데이트 할 데이터를 설정합니다.

Syntax

set ( $ key [, $ value = '' [, $ escape = NULL ]])

Parameters

  • $key( 혼합 ) − 필드 이름 또는 필드 / 값 쌍의 배열

  • $value( string ) − $ key가 단일 필드 인 경우 필드 값

  • $escape( bool ) − 값과 식별자를 이스케이프할지 여부

Returns

CI_DB_query_builder 인스턴스 (메서드 체인)

Return Type

CI_DB_query_builder

그만큼 where() 기능은 업데이트 할 레코드를 결정합니다.

Syntax

여기서 ( $ key [, $ value = NULL [, $ escape = NULL ]])

Parameters

  • $key( 혼합 ) − 비교할 필드 이름 또는 연관 배열

  • $value( 혼합 )-단일 키인 경우이 값과 비교

  • $escape( bool ) − 값과 식별자를 이스케이프할지 여부

Returns

DB_query_builder 인스턴스

Return Type

목적

마지막으로 update() 함수는 데이터베이스의 데이터를 업데이트합니다.

Syntax

update ([ $ table = '' [, $ set = NULL [, $ where = NULL [, $ limit = NULL ]]]])

Parameters

  • $table( 문자열 ) − 테이블 이름

  • $set( array ) − 필드 / 값 쌍의 연관 배열

  • $where( string ) − WHERE 절

  • $limit( int ) − LIMIT 절

Returns

성공하면 TRUE, 실패하면 FALSE

Return Type

부울
$data = array( 
   'roll_no' => ‘1’, 
   'name' => ‘Virat’ 
); 

$this->db->set($data); 
$this->db->where("roll_no", ‘1’); 
$this->db->update("stud", $data);

기록 삭제

데이터베이스에서 레코드를 삭제하려면 다음 표와 같이 delete () 함수를 사용합니다.

Syntax

delete ([ $ table = '' [, $ where = '' [, $ limit = NULL [, $ reset_data = TRUE ]]]])

Parameters

  • $table( 혼합 ) − 삭제할 테이블; 문자열 또는 배열

  • $where( string ) − WHERE 절

  • $limit( int ) − LIMIT 절

  • $reset_data( bool ) − 쿼리 "write"절을 재설정하려면 TRUE

Returns

CI_DB_query_builder 인스턴스 (메소드 체인) 또는 실패시 FALSE

Return Type

혼합

다음 코드를 사용하여 stud표. 첫 번째 인수는 레코드를 삭제할 테이블의 이름을 나타내고 두 번째 인수는 삭제할 레코드를 결정합니다.

$this->db->delete("stud", "roll_no = 1");

기록 선택

데이터베이스에서 레코드를 선택하려면 get 다음 표와 같이 함수가 사용됩니다.

Syntax

get ([ $ table = '' [, $ limit = NULL [, $ offset = NULL ]]])

Parameters

  • $table( string ) − 배열을 쿼리 할 테이블

  • $limit( int ) − LIMIT 절

  • $offset( int ) − OFFSET 절

Returns

CI_DB_result 인스턴스 (메소드 체인)

Return Type

CI_DB_result

다음 코드를 사용하여 데이터베이스에서 모든 레코드를 가져옵니다. 첫 번째 문은 "stud"테이블에서 모든 레코드를 가져와 $ query 개체에 저장 될 개체를 반환합니다. 두 번째 문은result() $ query 객체를 사용하여 모든 레코드를 배열로 가져옵니다.

$query = $this->db->get("stud"); 
$data['records'] = $query->result();

연결 닫기

다음 코드를 실행하여 데이터베이스 연결을 수동으로 닫을 수 있습니다.

$this->db->close();

라는 컨트롤러 클래스를 만듭니다. Stud_controller.php 그리고 그것을 저장하십시오 application/controller/Stud_controller.php

다음은 위에서 언급 한 모든 작업이 수행되는 완전한 예입니다. 다음 예제를 실행하기 전에이 장의 시작 부분에 설명 된대로 데이터베이스와 테이블을 만들고에 저장된 데이터베이스 구성 파일을 필요에 따라 변경합니다.application/config/database.php

<?php 
   class Stud_controller extends CI_Controller {
	
      function __construct() { 
         parent::__construct(); 
         $this->load->helper('url'); 
         $this->load->database(); 
      } 
  
      public function index() { 
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
			
         $this->load->helper('url'); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function add_student_view() { 
         $this->load->helper('form'); 
         $this->load->view('Stud_add'); 
      } 
  
      public function add_student() { 
         $this->load->model('Stud_Model');
			
         $data = array( 
            'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') 
         ); 
			
         $this->Stud_Model->insert($data); 
   
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function update_student_view() { 
         $this->load->helper('form'); 
         $roll_no = $this->uri->segment('3'); 
         $query = $this->db->get_where("stud",array("roll_no"=>$roll_no));
         $data['records'] = $query->result(); 
         $data['old_roll_no'] = $roll_no; 
         $this->load->view('Stud_edit',$data); 
      } 
  
      public function update_student(){ 
         $this->load->model('Stud_Model');
			
         $data = array( 
            'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') 
         ); 
			
         $old_roll_no = $this->input->post('old_roll_no'); 
         $this->Stud_Model->update($data,$old_roll_no); 
			
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function delete_student() { 
         $this->load->model('Stud_Model'); 
         $roll_no = $this->uri->segment('3'); 
         $this->Stud_Model->delete($roll_no); 
   
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
   } 
?>

라는 모델 클래스를 만듭니다. Stud_Model.php 그리고 그것을 저장하십시오 application/models/Stud_Model.php

<?php 
   class Stud_Model extends CI_Model {
	
      function __construct() { 
         parent::__construct(); 
      } 
   
      public function insert($data) { 
         if ($this->db->insert("stud", $data)) { 
            return true; 
         } 
      } 
   
      public function delete($roll_no) { 
         if ($this->db->delete("stud", "roll_no = ".$roll_no)) { 
            return true; 
         } 
      } 
   
      public function update($data,$old_roll_no) { 
         $this->db->set($data); 
         $this->db->where("roll_no", $old_roll_no); 
         $this->db->update("stud", $data); 
      } 
   } 
?>

라는보기 파일을 만듭니다. Stud_add.php 그리고 그것을 저장하십시오 application/views/Stud_add.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
   <body> 
         <?php 
            echo form_open('Stud_controller/add_student');
            echo form_label('Roll No.'); 
            echo form_input(array('id'=>'roll_no','name'=>'roll_no')); 
            echo "<br/>"; 
			
            echo form_label('Name'); 
            echo form_input(array('id'=>'name','name'=>'name')); 
            echo "<br/>"; 
			
            echo form_submit(array('id'=>'submit','value'=>'Add')); 
            echo form_close(); 
         ?> 
   </body>
</html>

라는보기 파일을 만듭니다. Stud_edit.php 그리고 그것을 저장하십시오 application/views/Stud_edit.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
	
   <body> 
      <form method = "" action = "">
		
         <?php 
            echo form_open('Stud_controller/update_student'); 
            echo form_hidden('old_roll_no',$old_roll_no); 
            echo form_label('Roll No.'); 
            echo form_input(array('id'⇒'roll_no',
               'name'⇒'roll_no','value'⇒$records[0]→roll_no)); 
            echo "
            "; 

            echo form_label('Name'); 
            echo form_input(array('id'⇒'name','name'⇒'name',
               'value'⇒$records[0]→name)); 
            echo "
            "; 

            echo form_submit(array('id'⇒'sub mit','value'⇒'Edit')); 
            echo form_close();
         ?> 
			
      </form> 
   </body>
	
</html>

라는보기 파일을 만듭니다. Stud_view.php 그리고 그것을 저장하십시오 application/views/Stud_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head>
	
   <body> 
      <a href = "<?php echo base_url(); ?>
         index.php/stud/add_view">Add</a>
		
      <table border = "1"> 
         <?php 
            $i = 1; 
            echo "<tr>"; 
            echo "<td>Sr#</td>"; 
            echo "<td>Roll No.</td>"; 
            echo "<td>Name</td>"; 
            echo "<td>Edit</td>"; 
            echo "<td>Delete</td>"; 
            echo "<tr>"; 
				
            foreach($records as $r) { 
               echo "<tr>"; 
               echo "<td>".$i++."</td>"; 
               echo "<td>".$r->roll_no."</td>"; 
               echo "<td>".$r->name."</td>"; 
               echo "<td><a href = '".base_url()."index.php/stud/edit/"
                  .$r->roll_no."'>Edit</a></td>"; 
               echo "<td><a href = '".base_url()."index.php/stud/delete/"
                  .$r->roll_no."'>Delete</a></td>"; 
               echo "<tr>"; 
            } 
         ?>
      </table> 
		
   </body>
	
</html>

경로 파일을 다음과 같이 변경하십시오. application/config/routes.php 파일 끝에 다음 줄을 추가하십시오.

$route['stud'] = "Stud_controller"; 
$route['stud/add'] = 'Stud_controller/add_student'; 
$route['stud/add_view'] = 'Stud_controller/add_student_view'; 
$route['stud/edit/(\d+)'] = 'Stud_controller/update_student_view/$1'; 
$route['stud/delete/(\d+)'] = 'Stud_controller/delete_student/$1';

이제 브라우저에서 다음 URL을 방문하여이 예제를 실행 해 보겠습니다. yoursite.com을 URL로 바꿉니다.

http://yoursite.com/index.php/stud