CSV 데이터를 가져오는 웹페이지를 만들 때 수십, 수백만 개의 데이터가 있는 경우 어떤 솔루션을 사용해야 하며 어떤 문제를 고려해야 합니까?
PHP를 사용하여 제목과 같은 웹 페이지를 만들고 싶습니다. 초보자는 어떻게 시작해야 할지 모릅니다. 이전에는 간단한 업로드를 했지만 이제 처리해야 할 데이터가 몇 천 개 밖에 되지 않습니다. 수백만 개의 데이터를 가져오면 어떻게 해결해야 합니까? 저는 Python을 알고 있지만 Python이 너무 까다로워서 PHP를 사용할 계획입니다. 조언 부탁드려요~
답글 내용:
PHP를 사용하여 제목과 같은 웹 페이지를 만들고 싶습니다. 초보자는 어떻게 시작해야 할지 모릅니다. 이전에는 간단한 업로드를 했지만 이제 처리해야 할 데이터가 몇 천 개 밖에 되지 않습니다. 수백만 개의 데이터를 가져오면 어떻게 해결해야 하나요? 저는 Python을 알고 있지만 Python이 너무 까다로워서 PHP를 사용할 계획입니다. 조언 부탁드려요~
효율성의 문제라면. 문자열로 연결하는 것은 >트랜잭션>> 루프 삽입과 같이...value(), value()에 삽입하는 것과 유사합니다. 한 가지 주의할 점은 한 번에 많은 양의 데이터를 삽입한다는 점이다. mysql이나 다른 데이터베이스에 한 번에 삽입할 수 있는 최대 데이터 양에 대한 구성을 수정해야 한다. 방금 해봤는데 한 번에 100,000개의 항목을 삽입하는 데 약 4초가 걸립니다(5개 필드가 있는 테이블의 경우)
데이터의 양이 상대적으로 크며 일괄적으로 가져올 수 있습니다. ajax를 사용하여 업로드 인터페이스를 반복적으로 요청하고 각 요청에 다른 매개변수를 전달합니다.
예:
www.xxx.com/upload.php?offset=0&length=1000
www.xxx.com/upload.php?offset=1000&length=1000
이렇게 하면 PHP 스크립트가 시간 초과되는 것을 방지할 수 있습니다.
삽입 문 최적화 및 테이블 구조에 대한 요구 사항이 크며, 그렇지 않으면 데이터 + 트랜잭션 + 정렬된 데이터를 병합하는 방법이 더 효율적입니다.
먼저 서버에 CSV 테이블을 업로드합니다.
그런 다음 PHP는 CSV 테이블을 MySQL 데이터베이스로 가져옵니다.
<code><?php //开启事务,批量插入 $db = new mysqli('127.0.0.1','user','pass','dbname',3306); $db->query('SET AUTOCOMMIT=0'); $db->query('START TRANSACTION'); //导入CSV表格:CSV转数组 $fp = fopen('file.csv', 'r'); while ( ($row = fgetcsv($fp)) !== FALSE ) { //从文件指针中读入一行并解析CSV $stmt = $db->prepare('INSERT INTO posts (id, post_title, post_content) VALUES (?,?,?)'); $stmt->bind_param('iss', $row[0], $row[1], $row[2]); //这里假设每行内容分别为ID,标题和内容 $stmt->execute(); //如果插入失败,改为更新 if($stmt->affected_rows == 0) { $stmt = $db->prepare('UPDATE posts SET post_title = ?, post_content = ? WHERE id = ?'); $stmt->bind_param('ssi', $row[1], $row[2], $row[0]); $stmt->execute(); if($stmt->affected_rows == 0) { echo 'Import '.$row[0].' failed!'."\n"; } } } fclose($fp); //提交事务 $db->query('COMMIT'); //失败的操作已经echo输出来了,不需要回滚ROLLBACK $db->query('SET AUTOCOMMIT=1');</code>
비동기식, 수백만 개의 동기화를 견딜 수 없습니다

핫 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.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다
