기본 콘텐츠로 건너뛰기

[PHP] Codeigniter (코드이그나이터) Model

[PHP] Codeigniter (코드이그나이터) Model

CI의 Model에 대해서 정리합니다.

MVC 디자인 패턴에서 M인 Model은 데이터를 담당합니다.

데이터란 보통 데이터베이스를 말하고 있습니다.

데이터를 다루는 로직을 따로 모델로 모아두어 데이터의 입출력과 화면을 관리하는 뷰를 격리 시켜

좀 더 편리하게 작업할 수 있는 환경을 그리고 호환성있게 만들어줄수 있습니다.

1. 데이터베이스 설정

Model을 사용하기 위해 CI의 데이터베이스 설정입니다.

Application/config/database.php 파일을 수정해야합니다.

주요 내요한 몇가지 설정만 해주시면 됩니다.

hostname : 데이터베이스 서버의 주소 username : 데이터베이스 사용자의 이름 password : 데이터베이스 비밀번호 database : 데이터베이스 명 dbdriver : 데이터베이스의 종류로 지원되는 드라이브의 목록은 system/database/drivers 디렉토리명을 참고한다.

※주의사항

데이터베이스 설정 파일에는 데이터베이스 서버에 접속 할 수 있는 정보를 그대로 입력하기 때문에

노출되서는 안됩니다. 따라서 버전관리를 사용하실때에는 제외해야합니다.

2. 데이터베이스 라이브러리 로드

CI에서 데이터베이스를 사용하기 위해서는 먼저 데이터베이스 라이브러리를 로드해야합니다.

CI에서는 2가지 방법을 제공해주고 있습니다.

1. application/config/autoload.php 파일의 $autoload['libraries'] 배열에 'database'를 추가한다. 2. controller 내에서 $this->load->database()를 호출한다.

※저는 2번째 방법으로 진행했습니다.

3. 모델 파일 생성

Model 파일은 Application/models 디렉토리 아래에 '모델명_model.php'의 형식으로 파일을 생성해주면 됩니다. Model 파일은 CI_Model을 상속받아야 합니다. 또한 클래스 명은 '모델명_model' 이어야 하며 첫글자는 대문자로 하셔야 합니다.

단순한 쿼리를 사용하기위해서는 아래와 같이 합니다.

$this->db->query("SELECT * FROM test");

쿼리의 결과를 가져오려면 아래와 같이 하시면 됩니다.

$this->db->query("SELECT * FROM test")->result();

result()는 쿼리의 결과를 가져오는 방법입니다.

연관배열의 형태로 결과를 가져오는 방법은 result_array()의 형태입니다.

결과가 한 행이라면 row()를 사용하셔도 좋습니다.

또한 CI에서는 Active Record라는 기능을 제공해줍니다.

Active Record는 좀 더 프로그래밍적으로 데이터베이스를 제어하는 방법으로

Active Record를 이용하면 표준 SQL을 생성 할 수 있어서 이식성이 좋아집니다.

Active Record 매뉴얼 : http://codeigniter-kr.org/user_guide_2.1.0/database/active_record.html

4.모델 사용

Model를 이용해 데이터를 조작하는 로직을 메소드로 정의하고

메소드는 Controller를 통해서 사용하면 됩니다.

모델을 사용하기 위해서는 먼저 모델을 로드합니다.

$this->load->model('모델파일이름');

모델의 메소드 호출하는 방법

$test_list = $this->test_model->gets();

-예제-

지난 포스팅에 했던 view에서 모델을 추가하여 작업하였습니다.

모델을 테스트하기 위해 다음과 같은 형식의 데이터베이스의 테이블을 생성했습니다.

create table test( seq int not null primary key, title varchar(255) not null, contents text not null, regdate datetime not null);

Application/controllers/test.php

load->database(); $this->load->model('test_model'); } public function index() { $this->load->view('header'); $test_list = $this->test_model->gets(); $this->load->view('test_list',array('test_list'=>$test_list)); $this->load->view('test'); $this->load->view('footer'); } public function Some($parameter) { $this->load->view('header'); $test_list = $this->test_model->gets(); $this->load->view('test_list',array('test_list'=>$test_list)); $test_item = $this->test_model->get2($parameter); $this->load->view('some',array('test_item'=>$test_item)); $this->load->view('footer'); } } ?>

Application/models/test_model.php

db->query($strQuery)->result(); } function get1($seq){ $strQuery = "SELECT * FROM test where seq = " . $seq; return $this->db->query($strQuery)->result(); } function get2($seq){ return $this->db->get_where('test',array('seq'=>$seq))->row(); } } ?>

Application/views/.php

title?> contents?>

Application/views/test_list.php

title?>

위 예제를 접속하면 다음과 같이 나옵니다.

아래는 데스트2의 타이틀을 클릭했을때 나오는 화면입니다.

데이터베이스에 들어가 있는 내용이 잘 나오는 것을 확인 할 수 있습니다.

※참고자료

Opentutorial - 생활코딩 Controller 편 : http://opentutorials.org/module/327/3827 Codeigniter Manual : http://codeigniter-kr.org/user_guide_2.1.0/general/models.html

#제 블로그 보다 Opentutoril의 생활코딩에 올라온 자료가 더 좋습니다. 공부하면서 정리하는 내용입니다.

-

- PHP, 코드이그나이터, codeigniter, 프레임워크, PHP 프레임워크 -

from http://yoshikixdrum.tistory.com/162 by ccl(A) rewrite - 2020-03-06 02:54:34

댓글

이 블로그의 인기 게시물

[PHP] 코드이그니터 - 파일업로드 구현

[PHP] 코드이그니터 - 파일업로드 구현 파일 업로드 이번에 PHP 프레임워크인 코드 이그니터(Codeigniter)를 사용하여 홈페이지를 만드는데 사용한 이미지 업로드용 코드 입니다. upload 라이브러리를 사용하고 app~ 와 같은 위치에 upload 폴더를 만드고 다음 코드를 사용한다음 ajax 로 호출하여 파일을 업로드 합니다. function index() { // Upload 설정 $config['upload_path'] = './upload/'; $config[\'allowed_types\'] = 'gif|jpg|png'; $config['max_size'] = 100; // 100k $config['max_width'] = 1024; $config['max_height'] = 768; $this->load->library('upload', $config); $data = array(); if (! $this->upload->do_upload("service_image")) { $error = array('error' => $this->upload->display_errors()); } else { //$data = array('upload_data' => $this->upload->data()); $this->output->set_output("./upload/".$this->upload->data('file_name')); } } jquery 를 이용한 파일 업로드 호출 코드 function upload() { var datas, xhr; datas = new FormData(); datas.append( 'service_image', $( ...

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술 php mysql linux android git kotlin gcm/fcm python mssql mongodb amazon aws ios objective-c swift github python c++ django python postgresql amazon aws html5/css3/javascript android java mysql python c++ c# java aws cloud-server dbms node.js postgresql redis nginx react.js hapi.js amazon aws restful-api angularJS jQuery html5/css3/javascript android firebase custom ui component restful-api asp.net c# html css javascript bootstrap angularjs node.js php mongodb redis 프론트엔드 주요 기술 javascript jquery ajax angularjs wbesocket html5/css3/javascript android ios java xcode node.js coffeescript mysql amazon ec2 amazon es3 android ios node.js php python java ios php mysql apache python android redis node.js jquery msa node.js java restful-api linux nosql golang redis nginx ...

이클립스 코드이그나이터 연동 ( eclipse codeigniter )

이클립스 코드이그나이터 연동 ( eclipse codeigniter ) https://ellislab.com/codeigniter/user-guide/installation/downloads.html 위의 사이트에서 코드이그나이터를 다운 받는다. 다운받은 압축 파일을 풀어 준다. 이클립스에서 php 프로젝트를 생성한 공간에 코드이그나이터 압축파일을 복사 붙여넣기 해준다. 위와 같은 화면이 나오면 정상적으로 연동이 된 것 입니다. from http://nahosung.tistory.com/22 by ccl(A) rewrite - 2020-03-06 16:20:55