>  기사  >  데이터 베이스  >  [mysql 튜토리얼] MySQL 메타데이터

[mysql 튜토리얼] MySQL 메타데이터

黄舟
黄舟원래의
2016-12-26 17:30:531114검색

MySQL 메타데이터

MySQL에 대한 다음 세 가지 유형의 정보를 알 수 있습니다.

쿼리 결과 정보: SELECT, UPDATE 또는 DELETE 문의 영향을 받는 레코드 수입니다.

데이터베이스 및 데이터 테이블 정보: 데이터베이스 및 데이터 테이블의 구조 정보를 담고 있습니다.

MySQL 서버 정보: 데이터베이스 서버의 현재 상태, 버전 번호 등이 포함됩니다.

MySQL 명령 프롬프트에서 위의 서버 정보를 쉽게 얻을 수 있습니다. 하지만 Perl이나 PHP와 같은 스크립트 언어를 사용하는 경우 이를 얻으려면 특정 인터페이스 함수를 호출해야 합니다. 다음에 자세히 소개하겠습니다.

쿼리문의 영향을 받은 레코드 개수 가져오기

PERL 인스턴스

DBI 스크립트에서는 쿼리문의 영향을 받은 레코드 개수를 do( ) 또는 실행():

# 方法 1
# 使用do( ) 执行  $query 
my $count = $dbh->do ($query);
# 如果发生错误会输出 0
printf "%d rows were affected\n", (defined ($count) ? $count : 0);

# 方法 2
# 使用prepare( ) 及 execute( ) 执行  $query 
my $sth = $dbh->prepare ($query);
my $count = $sth->execute ( );
printf "%d rows were affected\n", (defined ($count) ? $count : 0);

PHP 예제

PHP에서는 mysql_affected_rows() 함수를 사용하여 쿼리 문의 영향을 받는 레코드 수를 가져올 수 있습니다.

$result_id = mysql_query ($query, $conn_id);
# 如果查询失败返回 
$count = ($result_id ? mysql_affected_rows ($conn_id) : 0);
print ("$count rows were affected\n");

데이터베이스 및 데이터 테이블 목록

MySQL 서버에서 데이터베이스 및 데이터 테이블 목록을 쉽게 얻을 수 있습니다. 충분한 권한이 없으면 결과는 null이 됩니다.

SHOW TABLES 또는 SHOW DATABASES 문을 사용하여 데이터베이스 및 데이터 테이블 목록을 가져올 수도 있습니다.

PERL 인스턴스

# 获取当前数据库中所有可用的表。
my @tables = $dbh->tables ( );
foreach $table (@tables ){
   print "Table Name $table\n";
}

PHP 인스턴스

<?php
$con = mysql_connect("localhost", "userid", "password");
if (!$con)
{
  die(&#39;Could not connect: &#39; . mysql_error());
}

$db_list = mysql_list_dbs($con);

while ($db = mysql_fetch_object($db_list))
{
  echo $db->Database . "<br />";
}
mysql_close($con);
?>

서버 메타데이터 가져오기

다음 명령문은 MySQL 명령 프롬프트에서 사용할 수 있습니다. PHP 스크립트와 같은 스크립트에서도 사용할 수 있습니다.

명령

설명

SELECT VERSION( ) 서버 버전 정보

SELECT DATABASE( ) 현재 데이터베이스 이름(또는 공백 반환)

SELECT USER( ) 현재 사용자 이름

SHOW STATUS 서버 상태

SHOW VARIABLES 서버 구성 변수

위는 [ mysql 튜토리얼 】MySQL 메타데이터 콘텐츠, 더 많은 관련 콘텐츠를 보려면 PHP 중국어 웹사이트(www.php.cn)를 참고하세요!


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