PHP - AJAX 및 MySQL
AJAX를 사용하여 데이터베이스와 대화형으로 통신할 수 있습니다.
AJAX 데이터베이스 인스턴스
다음 예에서는 웹 페이지가 AJAX를 통해 데이터베이스에서 정보를 읽는 방법:
html 페이지 표시
예제 설명 - MySQL 데이터베이스
위 예에서 우리가 사용하는 데이터베이스 테이블은 다음과 같습니다.
예제 설명 - HTML 페이지
위 드롭다운 목록에서 사용자가 사용자를 선택하면 "showUser()"라는 함수가 실행됩니다. 이 함수는 "onchange" 이벤트에 의해 트리거됩니다.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script> function showUser(str) { if (str=="") { document.getElementById("txtHint").innerHTML=""; return; } if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp=new XMLHttpRequest(); } else { // IE6, IE5 浏览器执行代码 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById("txtHint").innerHTML=xmlhttp.responseText; } } xmlhttp.open("GET","getuser.php?q="+str,true); xmlhttp.send(); } </script> </head> <body> <form> <select name="users" onchange="showUser(this.value)"> <option value="">Select a person:</option> <option value="1">John Doe</option> <option value="2">tom Mary</option> <option value="3">lijing liuqi</option> <option value="4">liu li</option> </select> </form> <br> <div id="txtHint"><b>数据库信息展示在这</b></div> </body> </html>
showUser() 함수는 다음 단계를 수행합니다.
· 사용자가 선택되었는지 확인
· XMLHttpRequest 객체
· 서버 응답이 준비되었을 때 실행되는 함수 만들기
· 서버의 파일에 요청 보내기
· 매개변수(q)를 참고하세요. URL 끝에 추가됨(드롭다운 목록 콘텐츠 포함)
PHP 파일
위에서 호출한 서버 페이지 JavaScript를 통해 "database"라는 PHP 파일이 생성됩니다.
database.php"의 소스 코드는 MySQL 데이터베이스에 대해 쿼리를 실행하고 결과를 HTML 테이블로 반환합니다.
database.php 파일
<?php $q=$_GET["q"]; $con = mysqli_connect('localhost','root','root','test'); if (!$con) { die('Could not connect: ' . mysqli_error($con)); } //mysqli_select_db($con,"ajax_demo"); $sql="SELECT * FROM Myguests WHERE id = '".$q."'"; $result = mysqli_query($con,$sql); echo "<table border='1'> <tr> <th>firstname</th> <th>lastname</th> <th>email</th> <th>Age</th> </tr>"; while($row = mysqli_fetch_array($result)) { echo "<tr>"; echo "<td>" . $row['firstname'] . "</td>"; echo "<td>" . $row['lastname'] . "</td>"; echo "<td>" . $row['email'] . "</td>"; echo "<td>" . $row['Age'] . "</td>"; ; echo "</tr>"; } echo "</table>"; mysqli_close($con); ?>
설명: JavaScript에서 PHP 파일로 쿼리가 전송되면 다음과 같은 일이 발생합니다.
1. PHP는 MySQL 데이터베이스에 대한 연결을 엽니다.
2 . 선택된 사용자를 찾았습니다
3. HTML 양식을 만들고, 데이터를 입력하고, "txtHint" 자리 표시자를 다시 보냅니다.
프로그램 결과 표시: