데이터베이스 메타테이터 Database Metadata

테이블 메타테이터 Table MetaData

이 함수는 테이블에 대한 정보를 가져옵니다.

데이터베이스의 테이블을 나열 List the Tables in Your Database

$this->db->list_tables();

이 함수는 현재 연결된 데이터베이스의 모든 테이블 이름을 배열로 가지고 옵니다: 예제:

$tables = $this->db->list_tables();

foreach ($tables as $table)
{
        echo $table;
}

테이블이 존재하는지 확인 Determine If a Table Exists

$this->db->table_exists();

때로는 특정 테이블에 대해 작업을 실행하기 전에 테이블이 존재하는지 여부를 아는 것은 도움이 됩니다. TRUE/FALSE 값을 반환합니다. 사용 예제:

if ($this->db->table_exists('table_name'))
{
        // some code...
}

Note

table_name 부분을 여러분이 찾고 있는 테이블명을 넣어주세요.

필드 메타데이터 Field MetaData

테이블에서 필드명 나열 List the Fields in a Table

$this->db->list_fields()

필드(칼럼)이름을 배열로 리턴합니다. 이 쿼리는 두 가지 방법으로 호출할 수 있습니다:

1. 테이블 명을 넘겨주고 $this->db-> 객체를 사용하여 아래와 같이 사용합니다:

$fields = $this->db->list_fields('table_name');

foreach ($fields as $field)
{
        echo $field;
}

2. 쿼리를 이용하여 필드들을 지정한 효과를 낼 수 있습니다. 필드와 관련된 어떤 쿼리라도 상관 없습니다. (필드와 관련없는 함수 호출 쿼리는 안되겠죠) 아래 예제를 보시기 바랍니다:

$query = $this->db->query('SELECT * FROM some_table');

foreach ($query->list_fields() as $field)
{
        echo $field;
}

테이블에 필드명이 있는지 확인 Determine If a Field is Present in a Table

$this->db->field_exists()

쿼리를 실행하기 전에 관련 필드가 실제 존재하는지 검사할 때 유용합니다. 결과는 TRUE/FALSE 로 리턴됩니다. 사용 예제:

if ($this->db->field_exists('field_name', 'table_name'))
{
        // some code...
}

Note

field_name부분은 여러분이 실제로 조회하고자 하는 필드 이름으로 바꾸어 넣으세요 . table_name 부분도 여러분의 테이블명으로 하시구요.

필드 메타데이터 검색 Retrieve Field Metadata

$this->db->field_data()

필드정보를 담은 객체의 배열을 리턴합니다.

필드이름이나 칼럼타입, 최대길이(max length) 등의 메타데이터를 조회하는데 유용합니다.

Note

모든 데이터베이스가 메타데이터를 제공하지는 않습니다.

사용 예제:

$fields = $this->db->field_data('table_name');

foreach ($fields as $field)
{
        echo $field->name;
        echo $field->type;
        echo $field->max_length;
        echo $field->primary_key;
}

이미 실행한 쿼리가 있다면, 테이블 이름 대신 그 결과객체를 사용할 수도 있습니다:

$query = $this->db->query("YOUR QUERY");
$fields = $query->field_data();

이 함수를 호출하면, 여러분이 사용하는 데이터베이스에서 지원한다는 가정하에 다음의 데이터들이 사용 가능합니다:

  • name - 칼럼명(column name)
  • max_length - 칼럼의 최대길이(maximum length of the column)
  • primary_key - 해당칼럼이 기본키라면 1이됩니다(1 if the column is a primary key)
  • type - 칼럼타입(the type of the column)