PHP의 데이터베이스 쿼리 작업
관련 mysql 비디오 튜토리얼 권장 사항: "mysql 튜토리얼 "
#🎜 🎜 #
* 2 -5. mysqli_fetch_array($res,MYSQLI_BOTH): 인덱스 및 관계형 배열의 형태로 레코드를 반환합니다.
* 2-5. 객체 형태로 레코드를 반환합니다
# 🎜🎜# * mysqli_free_result($result); * 2-4: 현재 데이터 연결을 닫습니다#🎜 🎜#* 3. 쿼리 단계:#🎜 🎜#
* 3-1. 데이터베이스에 연결 * 3-2. 🎜🎜# * 3-3. 쿼리 실행#🎜 🎜# * 3-4. 테스트 결과
* 3-5. #
* 3-5-1. 삽입/업데이트/삭제인 경우: 영향을 받은 레코드 수를 반환합니다. * 3-6. 데이터베이스 연결을 닫습니다. 🎜#//1. 데이터베이스에 연결합니다. require는 함수가 아니므로 뒤에 괄호를 추가할 필요가 없습니다.# 🎜🎜#define ('DB_HOST', 'localhost'); define ('DB_USER', 'root'); define ('DB_PASS', 'root'); define ('DB_NAME', 'php'); define ('DB_CHAR', 'utf8'); $db = @mysqli_connect(DB_HOST, DB_USER, DB_PASS); if (mysqli_connect_errno($db)) { exit('连接失败'.mysqli_connect_error($db)); } mysqli_select_db($db, DB_NAME); mysqli_set_charset($db, DB_CHAR);
//2. SQL 문 준비
$sql = "SELECT name,salary FROM staff"; $sql = "SELECT name AS 姓名,salary AS 工资 FROM staff WHERE age>90";
/ /3. 쿼리 실행: 성공하면 결과 집합 개체가 반환되고, 실패하면 false가 반환됩니다.
$result = mysqli_query($db, $sql); var_dump($result);die();
//4. 감지 결과
//결과 집합이 존재하는 경우 #🎜 🎜#
if (false != $result) { //这是写只是语义性更强 //如果结果集中存在记录,至少有一条 // if (mysqli_num_rows($result) > 0) { //mysqli_affected_rows($db)也可以完成同样的检测工作,注意参数是连接对象$db,不是结果集对象 if (mysqli_affected_rows($db) > 0) { // echo '共计:'.mysqli_num_rows($result).'条记录<br>'; echo '共计:'.mysqli_affected_rows($db).'条记录~~<br>';
while($row = mysqli_fetch_array($result, MYSQLI_NUM)){
while($row = mysqli_fetch_row($result)){
while($row = mysqli_fetch_array($result, MYSQLI_ASSOC)){
while($row = mysqli_fetch_assoc($result)){
while($row = mysqli_fetch_array($result, MYSQLI_BOTH)){
while($row = mysqli_fetch_array($result)){
while($row = mysqli_fetch_object($result)){ // var_export($row);//以字符串方式表示查询结查 //如果是对象,可以用指向符来访问 echo $row->name.'--'.$row->salary; echo '<hr>'; //以变量方式表示,表示的内容更加完整丰富 // var_dump($row); } } else { echo '没有符合条件的记录'; } //查询失败的处理方式 } else { //必须要用exit()或die()终止脚本执行,否则后面的语句还会执行并会报错 exit('查询失败'.mysqli_errno($db).':'.mysqli_error($db)); }
mysqli_free_result($result);
//6 . 데이터베이스 연결을 닫습니다
mysqli_close($db);