PHP 팝업창을 통해 데이터베이스를 운영하는 방법
PHP 개발자로서 데이터베이스를 운영해야 하는 경우가 많습니다. 실제 프로젝트에서는 삭제, 수정 등의 일부 작업을 구현하기 위해 팝업 창을 사용해야 하는 경우가 많습니다.
이 글에서는 독자들이 이 기술을 더 잘 익힐 수 있도록 돕기 위해 PHP 팝업 창을 통해 데이터베이스를 작동하는 방법을 소개합니다.
1. 준비
팝업창을 구현하기 전에 다음 작업을 준비해야 합니다.
1. 데이터베이스 연결: PHP를 사용하여 데이터베이스 연결을 만들어야 합니다.
2. 데이터베이스 쿼리: 작동해야 하는 데이터를 얻으려면 PHP를 사용하여 데이터베이스를 쿼리해야 합니다.
3. 팝업창 코드: 팝업창 코드를 작성하려면 JavaScript나 jQuery를 사용해야 합니다.
시연의 편의를 위해 여기서는 MySQL을 데이터베이스로 사용하고 PHP PDO를 사용하여 데이터베이스에 연결합니다.
2. 데이터 삭제
아래에서는 팝업창을 통해 데이터를 삭제하는 방법을 소개하겠습니다. 먼저 데이터베이스에서 삭제할 데이터를 가져온 다음 이를 페이지에 표시하여 사용자 선택을 용이하게 해야 합니다.
1. 데이터 쿼리
다음 코드를 사용하여 삭제해야 하는 데이터를 쿼리할 수 있습니다.
<?php //连接数据库 $dsn = 'mysql:host=localhost;dbname=test;charset=utf8'; $username = 'root'; $password = '123456'; $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型 ]; $pdo = new PDO($dsn, $username, $password, $options); //查询要删除的数据 $sql = "SELECT * FROM test_table WHERE status = 0"; //status字段表示待删除数据 $stmt = $pdo->prepare($sql); $stmt->execute(); $data = $stmt->fetchAll(); ?>
위 코드에서는 먼저 데이터베이스에 연결하고 SELECT 문을 사용하여 삭제해야 하는 데이터를 쿼리합니다. 삭제됩니다. 그 중 상태 필드는 삭제할 데이터를 나타냅니다.
- 데이터 표시
다음으로 사용자가 선택할 수 있도록 쿼리된 데이터를 페이지에 표시합니다.
<table> <thead> <tr> <th>ID</th> <th>Name</th> <th>Email</th> <th>Action</th> </tr> </thead> <tbody> <?php foreach($data as $index=>$row): ?> <tr> <td><?php echo $row['id']; ?></td> <td><?php echo $row['name']; ?></td> <td><?php echo $row['email']; ?></td> <td><button class="delete-btn" data-id="<?php echo $row['id']; ?>">删除</button></td> </tr> <?php endforeach; ?> </tbody> </table>
위 코드에서는 HTML 테이블을 사용하여 쿼리된 데이터를 페이지에 표시합니다. 삭제 기능을 구현하기 위해 데이터의 각 행에 삭제 버튼을 추가하고 해당 ID 값을 data-id 속성을 통해 저장합니다.
- 데이터 삭제
마지막으로 삭제 기능을 구현해 보겠습니다. 사용자가 삭제 버튼을 클릭하면 사용자에게 데이터 삭제 여부를 묻는 확인 상자가 나타납니다. 사용자가 삭제를 확인하면 데이터베이스에서 데이터를 삭제하라는 AJAX 요청을 보냅니다.
$('.delete-btn').on('click', function() { var id = $(this).data('id'); if (confirm('确定要删除吗?')) { $.ajax({ url: 'delete.php', //处理删除请求的PHP文件 type: 'POST', data: {id: id}, success: function(res) { if (res.code === 0) { alert('删除成功'); window.location.reload(); //刷新页面 } else { alert('删除失败,请稍后再试'); } }, error: function() { alert('请求失败,请稍后再试'); } }); } });
위 코드에서는 jQuery를 사용하여 삭제 버튼의 클릭 이벤트를 바인딩했습니다. 사용자가 삭제 버튼을 클릭하면 먼저 데이터의 ID 값을 가져온 후 확인 기능을 사용하여 사용자에게 삭제 여부를 묻는 확인 상자가 나타납니다. 사용자가 확인을 클릭하면 delete.php 파일에 POST 요청을 보내 데이터베이스에서 데이터를 삭제합니다.
참고: delete.php 파일의 코드는 다음과 같습니다.
<?php //连接数据库 $dsn = 'mysql:host=localhost;dbname=test;charset=utf8'; $username = 'root'; $password = '123456'; $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型 ]; $pdo = new PDO($dsn, $username, $password, $options); //删除数据 $id = $_POST['id']; $sql = "DELETE FROM test_table WHERE id = :id"; $stmt = $pdo->prepare($sql); $stmt->bindParam(':id', $id, PDO::PARAM_INT); $res = $stmt->execute(); //返回结果 if ($res) { echo json_encode(['code' => 0, 'msg' => '删除成功']); } else { echo json_encode(['code' => 1, 'msg' => '删除失败']); } ?>
위 코드에서는 먼저 데이터베이스에 연결한 다음 DELETE 문을 사용하여 데이터베이스에서 데이터를 삭제합니다. 마지막으로 결과를 JSON 형식으로 반환합니다.
3. 데이터 수정
데이터 삭제 외에도 데이터를 수정해야 하는 경우가 많습니다. 아래에서는 팝업창을 통해 데이터를 수정하는 방법을 소개하겠습니다.
- 데이터 쿼리
먼저 수정해야 할 데이터를 데이터베이스에서 쿼리하여 사용자가 쉽게 수정할 수 있도록 페이지에 표시해야 합니다.
<?php //连接数据库 $dsn = 'mysql:host=localhost;dbname=test;charset=utf8'; $username = 'root'; $password = '123456'; $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型 ]; $pdo = new PDO($dsn, $username, $password, $options); //查询要修改的数据 $id = $_GET['id']; $sql = "SELECT * FROM test_table WHERE id = :id"; $stmt = $pdo->prepare($sql); $stmt->bindParam(':id', $id, PDO::PARAM_INT); $stmt->execute(); $data = $stmt->fetch(); ?>
위 코드에서는 먼저 $_GET['id']를 통해 수정이 필요한 데이터의 ID를 얻어옵니다. 그런 다음 SELECT 문을 사용하여 데이터베이스에서 데이터를 쿼리합니다.
- 데이터 표시
다음으로 사용자가 쉽게 수정할 수 있도록 쿼리된 데이터를 페이지에 표시합니다. 여기서는 여전히 HTML 양식을 사용하여 쿼리된 데이터를 양식에 채웁니다.
<form> <input type="hidden" name="id" value="<?php echo $data['id']; ?>"> <div> <label>Name:</label> <input type="text" name="name" value="<?php echo $data['name']; ?>"> </div> <div> <label>Email:</label> <input type="text" name="email" value="<?php echo $data['email']; ?>"> </div> <button class="submit-btn">保存</button> <button class="cancel-btn" type="button" onclick="history.back()">取消</button> </form>
수정해야 하는 데이터의 ID 값을 저장하기 위해 양식에 숨겨진 필드를 추가했습니다.
- 데이터 수정
마지막으로 수정 기능을 구현해 보겠습니다. 사용자가 저장 버튼을 클릭하면 수정된 데이터를 데이터베이스로 업데이트하기 위해 AJAX 요청을 보냅니다.
$('.submit-btn').on('click', function() { var data = $('form').serialize(); $.ajax({ url: 'update.php', //处理修改请求的PHP文件 type: 'POST', data: data, success: function(res) { if (res.code === 0) { alert('修改成功'); window.location.href = 'index.php'; //跳转到列表页 } else { alert('修改失败,请稍后再试'); } }, error: function() { alert('请求失败,请稍后再试'); } }); });
위 코드에서는 jQuery를 사용하여 저장 버튼의 클릭 이벤트를 바인딩했습니다. 사용자가 저장 버튼을 클릭하면 먼저 직렬화 기능을 통해 양식의 모든 데이터를 가져와 update.php 파일로 보냅니다. 여기서는 POST 메소드를 사용하여 데이터를 전송합니다.
참고: update.php 파일의 코드는 다음과 같습니다.
<?php //连接数据库 $dsn = 'mysql:host=localhost;dbname=test;charset=utf8'; $username = 'root'; $password = '123456'; $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型 ]; $pdo = new PDO($dsn, $username, $password, $options); //修改数据 $id = $_POST['id']; $name = $_POST['name']; $email = $_POST['email']; $sql = "UPDATE test_table SET name = :name, email = :email WHERE id = :id"; $stmt = $pdo->prepare($sql); $stmt->bindParam(':id', $id, PDO::PARAM_INT); $stmt->bindParam(':name', $name, PDO::PARAM_STR); $stmt->bindParam(':email', $email, PDO::PARAM_STR); $res = $stmt->execute(); //返回结果 if ($res) { echo json_encode(['code' => 0, 'msg' => '修改成功']); } else { echo json_encode(['code' => 1, 'msg' => '修改失败']); } ?>
위 코드에서는 먼저 데이터베이스에 연결한 다음 UPDATE 문을 사용하여 데이터를 데이터베이스에 업데이트합니다. 마지막으로 결과를 JSON 형식으로 반환합니다.
여기에서는 데모의 편의를 위해 직렬화 기능을 사용하여 양식 데이터를 문자열로 변환하지만 실제 프로젝트에서는 파일 업로드와 같은 기능을 지원하기 위해 일반적으로 FormData 개체를 사용하여 양식 데이터를 처리합니다.
4. 요약
본 글의 소개를 통해 PHP 팝업창을 통해 데이터베이스를 운용하는 방법을 알아보았습니다. 삭제든 수정이든 유사한 방법을 사용하여 이를 달성할 수 있습니다. 이 글이 독자들에게 도움이 되기를 바랍니다. 아직 이해가 되지 않는 부분이 있으면 토론을 위해 메시지를 남겨주세요.
위 내용은 PHP 팝업창을 통해 데이터베이스를 운영하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

이 기사는 MySQL 데이터베이스 상호 작용에 대한 PHP의 MySQLI_Query () 및 MySQLI_Fetch_Assoc () 함수에 대해 설명합니다. 그것은 그들의 역할, 차이점을 설명하고 그들의 사용의 실질적인 예를 제공합니다. 주요 논쟁은 USIN의 이점에 중점을 둡니다

기사는 PHP, 커버 단계, 보안 측정, 최적화 기술 및 Solutions의 일반적인 오류를 사용하여 데이터베이스에서 데이터 검색에 대해 논의합니다. 문자 수 : 159

이 기사는 CSRF 토큰, 동일한 사이트 쿠키 및 적절한 세션 관리를 포함하여 PHP의 CSRF 공격을 방지하는 전략에 대해 설명합니다.
