일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- FMS
- 라즈비안
- 제주도
- 맥
- 옵티머스g
- 옵지
- upbit
- 우분투
- 라라벨
- 라즈베리파이
- codeigniter
- 20.04
- Selenium
- 옵G
- 업비트
- 맛집
- TiL
- 우분투 20.04
- 옵티머스 g
- php
- ubuntu
- 회고
- 프레임워크
- C
- 셀레니움
- Laravel
- Ubuntu 20.04
- Raspberry Pi
- 코드이그나이터
- MySQL
- Today
- Total
평범한 이야기들
[PHP] Codeigniter (코드이그나이터) 데이터베이스 클래스 #2 본문
1. 쿼리 헬퍼 함수들
$this->db->insert_id()
데이터베이스에 레코드를 삽입할때 아이디번호를 삽입해줍니다.
$this->db->affected_rows()
insert, update등 뭔가를 쓰는 형태의 쿼리를 수행할때 적용된 결과 열수를 리턴합니다.
주의: MySQL 에서 "DELETE FROM TABLE" 쿼리에 이함수를 사용하면 0을 리턴하는 경우가 있습니다. 데이터베이스 클래스는 제대로된 열수를 리턴하는 방법을 핵(Hack)의 형태로 제공합니다. 기본값은 이 핵이 활성화된 상태이나 , 데이터베이스 드라이버파일에서 비활성으로 바꿀 수 있습니다.
$this->db->count_all();
특정 테이블의 열수를 리턴합니다. 테이블 이름을 첫번째 파라미터로 전달해야합니다. 예:
echo $this->db->count_all('my_table');
// Produces an integer, like 25
$this->db->platform()
현재 사용중인 데이터베이스 플랫폼(MySQL, MS SQL, Postgres, etc...)을 리턴합니다:
echo $this->db->platform();
$this->db->version()
사용중인 데이터베이스 버전을 리턴합니다:
echo $this->db->version();
$this->db->last_query();
마지막으로 사용한 쿼리 문자열을 리턴합니다(쿼리 실행결과가 아닙니다). 예:
$str = $this->db->last_query();
// Produces: SELECT * FROM sometable....
아래 두 함수는 INSERT와 UPDATE를 보다 간단하게 할수있도록 해줍니다.
$this->db->insert_string();
이 함수는 insert 를 간단하게 해줍니다.함수를 실행하면 , SQL insert 쿼리문을 자동으로 생성하여 리턴해 줍니다:
$data = array('name' => $name, 'email' => $email, 'url' => $url);
$str = $this->db->insert_string('table_name', $data);
첫번째 파라미터는 테이블 이름이며 , 두번째는 삽입될 데이터의 연관배열 입니다. 위 예제는 아래와같은 쿼리문자열을 자동으로 생성해 줍니다:
INSERT INTO table_name (name, email, url) VALUES ('Rick', 'rick@example.com', 'example.com')
$this->db->update_string();
이함수는 update 를 간단하게 해줍니다.SQL update 문자열을 자동으로 생성해주죠:
$data = array('name' => $name, 'email' => $email, 'url' => $url);
$where = "author_id = 1 AND status = 'active'";
$str = $this->db->update_string('table_name', $data, $where);
UPDATE table_name SET name = 'Rick', email = 'rick@example.com', url = 'example.com' WHERE author_id = 1 AND status = 'active'
쿼리결과헬퍼함수
$this->db->query("SELECT * FROM test")->num_rows() //쿼리 결과열의 갯수를 리턴합니다.
$this->db->query("SELECT * FROM test")->num_fields() //쿼리결과의 필드 갯수를 리턴합니다.