sql >> Database teknologi >  >> RDS >> Mysql

Hvordan kan jeg uploade individuelle CSV-rækker til forskellige tabeller i PHP?

I dit tilfælde er den bedste løsning den enkleste, så bare oprette fem forespørgsler, du kan endda gøre det i løkken:

$pdo = new PDO("mysql:host=127.0.0.1;dbname=yourdbname;charset=utf8", "username", "password");

if (($handle = fopen("test.csv", "r")) !== FALSE) {
    $row = 1;
    while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
        if ($row == 1) {
            $row++;
            continue;
        }
        $row++;

        foreach (['table1', 'table2', 'table3', 'table4', 'table5'] as $table) {
            $stmt = $pdo->prepare("INSERT INTO $table (name, title) VALUES (?,?)");
            $stmt->execute([$data[0], $data[1]]);
        }
    }
    fclose($handle);
}

Eller for OPDATERING med uid erstatte forech:

foreach (['table1', 'table2', 'table3', 'table4', 'table5'] as $table) {
    $stmt = $pdo->prepare("UPDATE $table SET name=?, title=? WHERE uid=?");
    $stmt->execute([$data[0], $data[1], $uid]);
}

Eller endnu bedre med INSERT eller UPDATE, bemærk, at i dette tilfælde bruger vi navngivne parametre.

foreach (['table1', 'table2', 'table3', 'table4', 'table5'] as $table) {
    $stmt = $pdo->prepare("INSERT INTO $table (uid, name, title) 
        VALUES (:uid, :name, :title) 
        ON DUPLICATE KEY UPDATE name=:name, title=:title");
    $stmt->bindValue('uid', $uid);
    $stmt->bindValue('name', $data[0]);
    $stmt->bindValue('title', $data[1]);
    $stmt->execute();
}

SQL for table1 .. table5

CREATE TABLE table1 (
 uid int(11) NOT NULL AUTO_INCREMENT,
 name varchar(255) NOT NULL,
 title varchar(255) NOT NULL,
 PRIMARY KEY (uid)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8

Bemærk: Når du vil beskrive bedre, hvordan vil du bevare det unikke, vil jeg nok tilføje nogle andre løsninger. I øjeblikket ved koden ikke, om James, chef fra CSV, er den samme James, chef i DB.




  1. Hvordan gemmer man europæisk valuta i MySQL?

  2. Sådan vælger du et dynamisk tabelnavn

  3. Grundlæggende Oracle Trigger revisionstabel

  4. Hvorfor er varigheden NULL for tilbagevendende begivenhed i Android?