>데이터 베이스 >MySQL 튜토리얼 >MySQL 쿼리 데이터

MySQL 쿼리 데이터

巴扎黑
巴扎黑원래의
2016-12-07 13:18:191263검색

MySQL 데이터베이스는 SQL SELECT 문을 사용하여 데이터를 쿼리합니다.

mysql> 명령 프롬프트 창을 통해 데이터베이스의 데이터를 쿼리하거나 PHP 스크립트를 통해 데이터를 쿼리할 수 있습니다.

다음은 MySQL 데이터베이스에서 데이터를 쿼리하기 위한 일반적인 SELECT 구문입니다.

SELECT 컬럼_이름, 컬럼_이름
FROM 테이블_이름[WHERE 절][OFFSET M ][LIMIT N]

쿼리 문에는 하나 이상의 테이블을 사용할 수 있으며, 쉼표(,)를 사용하여 테이블을 구분하고, WHERE 문을 사용하여 쿼리 조건을 설정합니다.

SELECT 명령은 하나 이상의 레코드를 읽을 수 있습니다.

별표(*)를 사용하여 다른 필드를 바꿀 수 있으며 SELECT 문은 테이블의 모든 필드 데이터를 반환합니다.

WHERE 문을 사용하여 모든 조건을 포함할 수 있습니다.

OFFSET을 사용하여 SELECT 문이 쿼리를 시작하는 데이터 오프셋을 지정할 수 있습니다. 기본적으로 오프셋은 0입니다.

LIMIT 속성을 사용하여 반환되는 레코드 수를 설정할 수 있습니다.

명령 프롬프트를 통해 데이터 가져오기

다음 예에서는 runoob_tbl 데이터 테이블의 모든 레코드를 반환합니다.

[root@localhost runoob]# mysql -u root -p 비밀번호 입력 :
MariaDB 모니터에 오신 것을 환영합니다. 명령은 ; 또는 g로 끝납니다.
MariaDB 연결 ID는 2입니다.
서버 버전: 5.5.50-MariaDB MariaDB 서버

저작권(c) 2000 , 2016, Oracle, MariaDB Corporation Ab 및 기타.

도움말을 보려면 'help;' 또는 'h'를 입력하세요. 현재 입력 문을 지우려면 'c'를 입력하세요.

MariaDB [(none ) ]> 테이블 및 열 이름 완성을 위해 RUNOOB 테이블 정보 읽기
-A를 사용하여 이 기능을 끌 수 있습니다.

데이터베이스 변경됨
MariaDB [RUNOOB]> * runoob_tbl
-> ;+------------+---------------+------------ - ---+------+
| runoob_title | runoob_author |
+---------- -+ ---------------+---------------+--- --+
| PHP 배우기 |
| MySQL 배우기 |
| -05 -06 |
| mysql | cakin24 2016-11-26 |
+---------+---- --------- +------+------+4개 행 set (0.00초)

MariaDB [RUNOOB]>

PHP 스크립트를 사용하여 데이터 가져오기

방법 1:

먼저 PHP 함수 mysql_query() 및 SQL SELECT 명령을 사용하여 데이터를 얻고, mysql_query 함수는 SQL 명령을 실행하는 데 사용됩니다.

그런 다음, 쿼리된 데이터는 PHP 함수 mysql_fetch_array()를 통해 처리됩니다.

mysql_fetch_array() 함수는 결과 집합에서 연관 배열, 숫자 배열 또는 둘 다로 행을 가져옵니다. 결과 집합에서 얻은 행에서 생성된 배열을 반환하거나, 쿼리 결과가 없으면 false를 반환합니다.

다음 예에서는 runoob_tbl 데이터 테이블의 모든 레코드를 읽습니다.

runoob_tbl 데이터 테이블의 모든 레코드를 표시하려면 다음 예를 시도해 보세요.

$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect( $dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('연결할 수 없습니다: ' . mysql_error());
}
$sql = 'SELECT runoob_id, runoob_title,
runoob_author, submit_date
FROM runoob_tbl';

mysql_select_db('RUNOOB');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
die('데이터를 가져올 수 없습니다: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC))
{
echo "튜토리얼 ID :{$row['runoob_id']}
".
"제목: {$row['runoob_title']}
".
" 작성자: {$row['runoob_author']}
".
"제출 날짜: {$row['submission_date']}
".
"------ - ---------
";
}
echo "데이터를 성공적으로 가져왔습니다";
mysql_close( $conn) ;
?>

위의 예에서 읽은 레코드의 각 행은 $row 변수에 할당된 다음 각 값이 인쇄됩니다.

참고: 문자열에 변수를 사용해야 하는 경우 변수를 중괄호 안에 넣으세요.

위 예에서 PHP mysql_fetch_array() 함수의 두 번째 매개변수는 MYSQL_ASSOC입니다. 이 매개변수로 설정하면 쿼리 결과가 연관 배열을 반환합니다. 정렬.

방법 2:

PHP는 결과 집합에서 연관 배열로 행을 가져오는 또 다른 함수 mysql_fetch_assoc()를 제공합니다. 결과 집합에서 가져온 행을 기반으로 연관 배열을 반환하거나 더 이상 행이 없으면 false를 반환합니다.

다음 예에서는 mysql_fetch_assoc() 함수를 사용하여 runoob_tbl 데이터 테이블의 모든 레코드를 출력합니다.

$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die ('연결할 수 없습니다: ' . mysql_error());
}
$sql = 'SELECT runoob_id, runoob_title,
runoob_author, submit_date
FROM runoob_tbl';

mysql _select_db( 'RUNOOB');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
die('데이터를 가져올 수 없습니다: ' . mysql_error ()) ;
}
while($row = mysql_fetch_assoc($retval))
{
echo "튜토리얼 ID :{$row['runoob_id']}
".
" 제목: {$row['runoob_title']}
".
"저자: {$row['runoob_author']}
".
"제출 날짜: {$ row[' submit_date']}
".
" "--------------------------------
";
}
echo "데이터를 성공적으로 가져왔습니다.";
mysql_close($conn);
?>

방법 3:

또한 MYSQL_NUM 상수를 PHP mysql_fetch_array() 함수의 두 번째 매개변수로 사용하여 숫자 배열을 반환할 수도 있습니다.

다음 예에서는 MYSQL_NUM 매개변수를 사용하여 runoob_tbl 데이터 테이블의 모든 레코드를 표시합니다.

$dbhost = 'localhost:3036';
$dbuser = 'root' ;
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
죽다 ('연결할 수 없습니다: ' . mysql_error());
}
$sql = 'SELECT runoob_id, runoob_title,
runoob_author, submit_date
FROM runoob_tbl';

mysql_select_db ('RUNOOB') ;
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
die('데이터를 가져올 수 없습니다: ' . mysql_error() );
}
while($row = mysql_fetch_array($retval, MYSQL_NUM))
{
echo "튜토리얼 ID :{$row[0]}
".
"제목: {$ row[1]}
".
"저자: {$row[2]}
".
"제출 날짜: {$row[3]} < ;br> ".
"-------------------
";
}
echo "데이터를 성공적으로 가져왔습니다";
mysql_close($conn);
?>

위 세 가지 예의 출력 결과는 동일합니다.

MySQL 쿼리 데이터

메모리 해제

SELECT 문을 실행한 후에는 커서 메모리를 해제하는 것이 좋은 습관입니다. 메모리 해제는 PHP 함수 mysql_free_result()를 통해 수행할 수 있습니다.

다음 예에서는 이 기능의 사용을 보여줍니다. 이 예에서는 이전 예를 기반으로 mysql_free_result($retval); 문만 추가합니다.

$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect( $dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('연결할 수 없습니다: ' . mysql_error());
}
$sql = 'SELECT runoob_id, runoob_title,
runoob_author, submit_date
FROM runoob_tbl';

mysql_select_db('RUNOOB');$retval = mysql_query( $sql, $conn );
if(! $retval )
{
die('데이터를 가져올 수 없습니다: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_NUM))
{
echo "튜토리얼 ID:{$row[0]}
".
"제목: {$row[1]}
".
"저자: {$row[2 ]}
".
" "제출 날짜: {$row[3]}
".
" "---------------- --------------
";
}mysql_free_result($retval);echo "데이터를 성공적으로 가져왔습니다.";
mysql_close($conn);
? >


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