백엔드 개발 PHP 문제 PHP로 전송을 작성하는 방법

PHP로 전송을 작성하는 방법

Apr 04, 2023 am 09:01 AM

오늘날 금융 분야에서 계좌 간 자금 이체는 일상생활에서 흔한 작업이 되었습니다. 웹 개발에서도 이런 종류의 작업은 매우 일반적입니다. PHP는 비교적 간단한 학습 곡선과 강력한 확장성으로 인해 웹 개발에 널리 사용되는 언어입니다. PHP에서는 계좌이체 기능을 쉽게 구현할 수 있습니다. 다음으로, 이 기사에서는 PHP에서 계정 전송을 배우는 방법을 안내합니다.

시작하기 전에 먼저 개념을 명확히 해야 합니다. 자금 이체의 핵심은 데이터베이스 운영에 있습니다. 개발에 어떤 언어를 사용하든 결국에는 데이터베이스에서 작업해야 합니다.

먼저 데이터베이스에 두 개의 테이블을 생성해야 합니다. 하나는 사용자 테이블이고 다른 하나는 전송 기록 테이블입니다. 사용자 테이블에는 각 사용자의 계정 잔액은 물론 전화번호, 이메일 주소 등과 같은 기타 관련 정보도 기록됩니다. 이체기록표에는 이체금액, 시간, 이체인, 수취인 등 이용자 간 이체정보가 기록됩니다. 이 두 테이블은 MySQL 및 PostgreSQL과 같은 관계형 데이터베이스를 사용하여 생성할 수 있습니다. 여기서는 MySQL을 예로 들어보겠습니다.

CREATE TABLE users (
    id INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL,
    phone VARCHAR(20) NOT NULL,
    balance DECIMAL(10,2) NOT NULL
);

CREATE TABLE transfers (
    id INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
    from_user_id INT(11) NOT NULL,
    to_user_id INT(11) NOT NULL,
    amount DECIMAL(10,2) NOT NULL,
    date DATETIME NOT NULL,
    FOREIGN KEY (from_user_id) REFERENCES users(id),
    FOREIGN KEY (to_user_id) REFERENCES users(id)
);
로그인 후 복사

위는 두 개의 테이블을 생성하는 SQL 문입니다. 이 명령문을 수동으로 실행하거나 PHP 코드를 사용하여 생성할 수 있습니다.

다음으로 PHP 코드로 데이터베이스에 연결하고 PHP에서 MySQLi 확장을 사용하여 연결을 만들어야 합니다.

<?php
$host = &#39;localhost&#39;;
$username = &#39;your_username&#39;;
$password = &#39;your_password&#39;;
$dbname = &#39;your_database&#39;;

$mysqli = new mysqli($host, $username, $password, $dbname);

if ($mysqli->connect_error) {
    die('连接数据库失败: ' . $mysqli->connect_error);
}

echo '连接数据库成功!';
?>
로그인 후 복사

다음으로 사용자 간 전송 작업을 구현해야 합니다. 먼저, 이체를 진행하는 양측의 계좌 잔액이 이체 조건을 충족하는지 확인해야 합니다. 조건이 충족되면 MySQL의 트랜잭션 기능을 사용하여 데이터에 대한 원자적 작업을 수행해야 합니다. 다음은 MySQLi 확장을 사용하여 이체 작업을 구현하는 코드입니다.

<?php
$mysqli->autocommit(FALSE); // 开始事务

$from_user_id = 1;
$to_user_id = 2;
$amount = 500;

// 查询原账户余额
$result = $mysqli->query("SELECT balance FROM users WHERE id=$from_user_id");
$row = $result->fetch_assoc();
$from_user_balance = $row['balance'];
$result->free();

if ($from_user_balance >= $amount) {
    $result = $mysqli->query("SELECT balance FROM users WHERE id=$to_user_id");
    $row = $result->fetch_assoc();
    $to_user_balance = $row['balance'];
    $result->free();

    $from_user_balance -= $amount;
    $to_user_balance += $amount;

    $mysqli->query("UPDATE users SET balance=$from_user_balance WHERE id=$from_user_id");
    $mysqli->query("UPDATE users SET balance=$to_user_balance WHERE id=$to_user_id");

    $mysqli->query("INSERT INTO transfers (from_user_id, to_user_id, amount, date) VALUES ($from_user_id, $to_user_id, $amount, NOW())");

    if ($mysqli->commit()) {
        echo "转账成功!";
    } else {
        echo "转账失败!";
    }
} else {
    echo "账户余额不足!";
}

$mysqli->close();
?>
로그인 후 복사

위 코드는 계정 1에서 계정 2로 500위안을 이체하는 작업을 구현합니다. 코드에서는 먼저 MySQL의 트랜잭션 기능을 활성화하여 데이터의 원자성을 보장합니다. 그런 다음 계정 1과 계정 2의 계정 잔액을 쿼리하고 데이터베이스 레코드를 업데이트합니다. 마지막으로 이적기록표에 이적정보를 기록하였습니다.

요약하면 PHP에서 이체 작업을 구현하는 단계는 다음과 같습니다.

  1. 사용자 양식 생성 및 이체 기록 양식
  2. 데이터베이스에 연결
  3. 계정 잔액이 이체 조건을 충족하는지 확인
  4. 거래 열기 및 수행 데이터베이스 작업
  5. 기록 전송 기록
  6. 트랜잭션 커밋

실제 개발에서는 프로그램의 보안과 데이터의 무결성을 보장하기 위해 오류 처리 및 데이터 검증을 수행해야 한다는 점에 주목할 가치가 있습니다.

위 내용을 학습한 후 PHP에서 전송 작업을 구현하는 방법을 마스터했다고 생각합니다. 실제 개발에서는 실제 상황에 따라 유연하게 적용하고 코드의 가독성과 유지 관리성을 보장하기 위해 좋은 프로그래밍 관행을 따라야 합니다.

위 내용은 PHP로 전송을 작성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

최신 PHP 코딩 표준 및 모범 사례는 무엇입니까? 최신 PHP 코딩 표준 및 모범 사례는 무엇입니까? Mar 10, 2025 pm 06:16 PM

이 기사에서는 PSR 권장 사항 (PSR-1, PSR-2, PSR-4, PSR-12)에 중점을 둔 현재 PHP 코딩 표준 및 모범 사례를 검토합니다. 일관된 스타일링, 의미있는 이름 지정 및 EFF를 통해 코드 가독성 및 유지 관리 개선을 강조합니다.

PHP에서 메시지 대기열 (Rabbitmq, Redis)을 구현하는 방법은 무엇입니까? PHP에서 메시지 대기열 (Rabbitmq, Redis)을 구현하는 방법은 무엇입니까? Mar 10, 2025 pm 06:15 PM

이 기사는 RabbitMQ 및 Redis를 사용하여 PHP에서 메시지 대기열을 구현하는 것을 자세히 설명합니다. 그것은 그들의 아키텍처 (AMQP 대 메모리), 기능 및 신뢰성 메커니즘 (확인, 트랜잭션, 지속성)을 비교합니다. 설계, 오류에 대한 모범 사례

PHP 확장 및 PECL로 어떻게 작업합니까? PHP 확장 및 PECL로 어떻게 작업합니까? Mar 10, 2025 pm 06:12 PM

이 기사는 PECL에 중점을 둔 PHP 확장을 설치 및 문제 해결에 대해 자세히 설명합니다. 설치 단계 (찾기, 다운로드/컴파일, 서버 활성화, 다시 시작), 문제 해결 기술 (로그 확인, 설치 확인, 설치 확인,

반사를 사용하여 PHP 코드를 분석하고 조작하는 방법은 무엇입니까? 반사를 사용하여 PHP 코드를 분석하고 조작하는 방법은 무엇입니까? Mar 10, 2025 pm 06:12 PM

이 기사는 PHP의 반사 API를 설명하여 런타임 검사 및 클래스, 방법 및 속성의 조작을 가능하게합니다. 일반적인 사용 사례 (문서 생성, ORM, 종속성 주입)에 대해 자세히 설명하고 성능에 대한 경고

PHP 8 JIT (정시) 편집 : 성능 향상 방법. PHP 8 JIT (정시) 편집 : 성능 향상 방법. Mar 25, 2025 am 10:37 AM

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

PHP 생태계 및 커뮤니티를 어떻게 최신 상태로 유지합니까? PHP 생태계 및 커뮤니티를 어떻게 최신 상태로 유지합니까? Mar 10, 2025 pm 06:16 PM

이 기사는 PHP 생태계에서 최신 상태를 유지하기위한 전략을 탐구합니다. 공식 채널, 커뮤니티 포럼, 컨퍼런스 및 오픈 소스 기부금을 강조합니다. 저자는 새로운 기능을 배우기위한 최고의 리소스와

PHP에서 메모리 최적화 기술을 사용하는 방법은 무엇입니까? PHP에서 메모리 최적화 기술을 사용하는 방법은 무엇입니까? Mar 10, 2025 pm 04:23 PM

이 기사는 PHP 메모리 최적화를 다룹니다. 적절한 데이터 구조 사용, 불필요한 객체 생성을 피하고 효율적인 알고리즘을 사용하는 것과 같은 기술을 자세히 설명합니다. 공통 메모리 누출 소스 (예 : 미세한 연결, Global v

비 차단 작업에 PHP에서 비동기 작업을 사용하는 방법은 무엇입니까? 비 차단 작업에 PHP에서 비동기 작업을 사용하는 방법은 무엇입니까? Mar 10, 2025 pm 04:21 PM

이 기사는 웹 응용 프로그램 응답 성을 향상시키기 위해 PHP에서 비동기 작업 실행을 탐구합니다. 메시지 대기열, 비동기 프레임 워크 (Reactphp, Swoole) 및 백그라운드 프로세스와 같은 방법을 자세히 설명합니다.

See all articles