PHP가 XML을 구문 분석하고 SQL 문을 생성하는 단계에 대한 자세한 설명
이번에는 PHP가 xml을 구문 분석하고 sql 문을 생성하는 단계에 대해 자세히 설명하겠습니다. php에서 xml을 구문 분석하고 sql 문을 생성하는 데 있어 주의 사항은 무엇입니까? 다음은 실제 사례입니다.
PHP에서 xml을 구문 분석하는 방법은 여러 가지가 있으며 문서에서 검색해 보세요.
오늘 요구 사항이 발생했습니다. 특정 XML에서 노드 속성을 추출한 다음 데이터베이스 테이블의 필드를 업데이트해야 합니다.
아이디어:
XML을 구문 분석하고 모든 노드 속성을 가져옵니다. –> 노드 컬렉션을 반복하고 해당 속성을 가져옵니다. –> SQL 문자열을 연결하여 배열에 저장합니다. 여기서는
xpath가 사용됩니다. 코드를 작성하는 중에 두 가지 문제가 발생했습니다.
1.xml의 기록 경로 속성이 D:xx인 경우 파일을 로드할 수 없습니다. , 따라서 "/"(리눅스 아래) 구분 기호로 변경됩니다.
2. 노드의 속성을 얻으려면 ::attributes를 사용하세요. 편집기는 빨간색으로 계속 메시지를 표시하고 반나절 문서를 찾은 다음 마지막으로 다음을 사용합니다. ->getAttribute() (너무 이상해서 ->previousSibling 및 ->nodeValue를 지원하는 것 같아요.) 문서에 따르면 DOMElement::getAttribute는 직접 오류를 보고합니다.
다음은 다음과 같습니다. 샘플 코드:
<title>xml 转换为 sql</title> <meta http-equiv='content-type' content='text/html; charset=utf-8' /> <style type="text/css"> .tip_info {margin-bottom:10px;} .tip_info span {color:#f00;} </style> <?php $xml = "D:/res/dressConfig.xml"; $doc = new DOMDocument(); $doc->load($xml); $xpath = new DOMXPath($doc); $query = "//i"; $entries = $xpath->query($query); $len = $entries->length; echo "<p class='tip_info'>总共找到:<span>".$len."</span>个节点</p>"; $arr = array(); $idx = 0; while ($idx < $len) { $nodeItem = $entries->item($idx); $id = $nodeItem->getAttribute("i"); $name = $nodeItem->getAttribute("n"); $inf = $nodeItem->getAttribute("inf"); // echo "<p>".$id.'--'.$name.'--'.$inf."</p>"; $idx++; array_push($arr, "update dress_item t SET t.s_name='".$name."',t.s_intro='".$inf."' WHERE t.n_doid=".$id.";"); } $dir = "d:/sql/"; if (!is_dir($dir)) { mkdir($dir); } file_put_contents("d:/sql/dress_item.sql", implode("\n\r", $arr)); echo "生成完毕!"; ?>
데이터는 에서 생성된 데이터베이스 테이블에서 가져온 것이므로 발견된 노드 수는 테이블의 총 레코드 수입니다. 생성 후 내용이 올바른지 살펴본 후 SQL 스크립트를 실행하여 목적을 달성할 수 있습니다.
이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
php 및 js로 로컬 exe 애플리케이션을 열 때 매개변수를 전달하는 단계에 대한 자세한 설명
PHP 클래스 리플렉션을 사용하여 종속성 주입을 구현하는 단계에 대한 자세한 설명
위 내용은 PHP가 XML을 구문 분석하고 SQL 문을 생성하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

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

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

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