> 백엔드 개발 > PHP 문제 > PHP에서 데이터베이스에 배열을 저장하는 방법

PHP에서 데이터베이스에 배열을 저장하는 방법

PHPz
풀어 주다: 2023-04-19 14:08:02
원래의
1105명이 탐색했습니다.

PHP 프로그래밍에서 배열은 데이터를 편리하게 저장하고 관리할 수 있는 매우 일반적으로 사용되는 데이터 구조입니다. 데이터베이스에 배열을 저장하는 것은 일상적인 응용 프로그램에서도 일반적인 작업입니다. 이 기사에서는 PHP에서 데이터베이스에 배열을 저장하는 방법을 소개합니다.

  1. 데이터베이스에 연결

배열을 저장하기 전에 PHP를 사용하여 데이터베이스에 연결해야 합니다. PHP의 mysqli 또는 PDO 확장을 통해 MySQL과 같은 데이터베이스와의 연결이 가능합니다.

먼저 호스트 주소, 사용자 이름, 비밀번호, 데이터베이스 이름 등을 포함하여 PHP에서 데이터베이스 연결 정보를 구성해야 합니다.

그런 다음 mysqli_connect() 또는 PDO의 connect() 메서드를 사용하여 연결할 수 있습니다. 대상 데이터베이스.

예:

//mysqli_connect()를 사용하여 데이터베이스에 연결
$servername = "localhost";
$username = "root";
$password = "123456";
$dbname = "test";

$conn = mysqli_connect($servername, $username, $password, $dbname);
if (!$conn) {

die("Connection failed: " . mysqli_connect_error());
로그인 후 복사

}

//PDO를 사용하여 데이터베이스에 연결
$dsn = 'mysql: dbname=test;host=localhost ';
$user = 'root';
$password = '123456';

try {

$dbh = new PDO($dsn, $user, $password);
로그인 후 복사

} catch (PDOException $e) {

echo 'Connection failed: ' . $e->getMessage();
로그인 후 복사

}

  1. 데이터 생성 table

다음으로, 대상 데이터베이스에서 배열을 저장할 데이터 테이블을 먼저 생성해야 합니다. MySQL 명령줄이나 시각화 도구를 사용하여 저장해야 하는 데이터가 포함된 테이블을 만들 수 있습니다.

예: 학생 ID, 이름, 나이를 포함한 일련의 학생 정보를 저장해야 한다고 가정하면 다음 데이터 테이블을 만들 수 있습니다.

CREATE TABLE students (students (
 id int(10) unsigned NOT NULL AUTO_INCREMENT,
 name varchar(20) NOT NULL DEFAULT '',
 age int(11) NOT NULL DEFAULT '0',
 PRIMARY KEY (id id int(10 ) unsigned NOT NULL AUTO_INCREMENT,
name varchar(20) NOT NULL DEFAULT '',

age int(11) NOT NULL DEFAULT '0 ',
    PRIMARY KEY (id)
  1. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Storage array

다음으로 PHP 배열의 데이터를 데이터 테이블에 삽입할 수 있습니다. MySQL INSERT 명령이나 PHP에서 제공하는 함수를 사용하여 대상 데이터 테이블에 배열을 삽입하는 삽입 작업을 수행할 수 있습니다.


예를 들어 위의 데이터 테이블에 세 명의 학생 정보가 포함된 배열을 삽입하려면 다음 코드를 사용할 수 있습니다.

//세 명의 학생 정보가 포함된 배열
$students = array(
array('name' => ; '张三', 'age' => 18),

array('name' => 'lee思', 'age' => 19),

array('name' => ' 왕우 ', 'age' => 20)
);

//배열을 반복하고 각 학생 정보를 데이터 테이블에 삽입합니다

foreach ($students as $student) {

$name = $student['name ' ];
$age = $student['age'];

//mysqli를 사용하여 구현

$sql = "INSERT INTO 학생 (이름, 나이) VALUES ('$name', $age)";

if ( mysqli_query($conn, $sql)) {

echo "New record created successfully";
로그인 후 복사
} else {

echo "Error: " . $sql . "<br>" . mysqli_error($conn);
로그인 후 복사

}

//PDO를 사용하여 구현
$stmt = $dbh->prepare("INSERT INTO 학생 (이름, 나이) VALUES ( : 이름, :age)");
$stmt->bindParam(':name', $name); $stmt->bindParam(':age', $age);
    $stmt->execute ( );
  1. }

데이터 쿼리

배열을 데이터베이스에 저장한 후 MySQL 명령줄이나 PHP 코드를 통해 데이터 테이블의 데이터를 쿼리할 수도 있습니다. SELECT 명령이나 PHP에서 제공하는 쿼리 연산 기능을 이용하여 데이터 테이블을 쿼리할 수 있습니다.


예: 데이터 테이블에 포함된 모든 학생 정보를 쿼리하려면 다음 코드를 사용할 수 있습니다.

//mysqli를 사용하여 구현
$sql = "SELECT * FROM Students";

$result = mysqli_query($conn , $sql);

if (mysqli_num_rows($result) > 0) {
while($row = mysqli_fetch_assoc($result)) {

echo "id: " . $row["id"]. " - Name: " . $row["name"]. " - Age: " . $row["age"]. "<br>";
로그인 후 복사

}} else {

echo "결과 0개";
}

//PDO를 사용하여
$stmt = $dbh->prepare("SELECT * FROM Students");
$stmt->execute();

$res = $stmt->fetchAll();

if 구현 (count($res) > 0) {
foreach ($res as $row) {

echo "id: " . $row['id'] . " - Name: " . $row['name'] . " - Age: " . $row['age'] . "<br>";
로그인 후 복사

}} else {

echo "0 results";

}

요약🎜🎜PHP 프로그래밍에서 배열을 일반적인 작업의 경우 MySQL INSERT 명령이나 PHP에서 제공하는 함수를 통해 대상 데이터 테이블에 배열을 삽입하여 삽입 작업을 수행할 수 있습니다. 동시에 MySQL의 SELECT 명령이나 PHP에서 제공하는 쿼리 연산 기능을 통해 데이터 테이블을 쿼리할 수도 있습니다. 이 방법을 사용하면 데이터의 저장과 관리가 간편해지며, 일상 업무에서도 꼭 필요한 작업입니다. 🎜

위 내용은 PHP에서 데이터베이스에 배열을 저장하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿