Php MySQLi将表导出到CSV

Php MySQLi将表导出到CSV,php,csv,mysqli,export,Php,Csv,Mysqli,Export,我已经尝试了好几天使用MySQLi从一个查询中导出.csv中的一些值,但是在导出时我遇到了一个问题,所有内容都导出到一个列中,相反,我需要导出类似SQL代码的内容。我在.cvs中有3个选定列和3个导出列。 下面您可以找到两个代码: 1此代码创建数据库、表格并插入值: <?php $servername = "localhost"; $username = "root"; $password = ""; $dbname = "myDB"; // Create connection $conn

我已经尝试了好几天使用MySQLi从一个查询中导出.csv中的一些值,但是在导出时我遇到了一个问题,所有内容都导出到一个列中,相反,我需要导出类似SQL代码的内容。我在.cvs中有3个选定列和3个导出列。 下面您可以找到两个代码:

1此代码创建数据库、表格并插入值:

<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password);
// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}
// Create database
$sql = "CREATE DATABASE myDB";
if ($conn->query($sql) === TRUE) {
    echo "Database created successfully";
} else {
    echo "Error creating database: " . $conn->error;
}
// Create connection pt a crea tabela
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "CREATE TABLE MyGuests (
    id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    firstname VARCHAR(30) NOT NULL,
    lastname VARCHAR(30) NOT NULL,
    email VARCHAR(50),
    reg_date TIMESTAMP
)";
if ($conn->query($sql) === TRUE) {
    echo "Table MyGuests created successfully";
} else {
    echo "Error creating table: " . $conn->error;
}
// Create connection pt a insera valori
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}
// Insert value in db
$sql = "INSERT INTO MyGuests (firstname, lastname, email)
    VALUES ('John', 'Doe, Mark', 'john@example.com'),
    ('Mary', 'Moe-Johny', 'mary@example.com'),
    ('Julie', 'Dooley', 'julie@example.com')";
if ($conn->query($sql) === TRUE) {
    echo "New record created successfully";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
?>
我正在使用这个XAMP版本:

Apache/2.4.18 Win32 OpenSSL/1.0.2e PHP/7.0.1

数据库客户端版本:libmysql-mysqlnd 5.0.12-dev-20150407-$Id:7e72f9690b1498a1bead7a637c33a831c0d2f655$

PHP扩展:mysqli文档

PHP版本:7.0.1

这个版本给MySQL代码带来了一些问题,这就是为什么我更喜欢MySQLi中的代码。
多谢各位

根据新信息,我将此作为解决方案

<?php

// call export function
exportMysqlToCsv('export_csv.csv');


// export csv
function exportMysqlToCsv($filename = 'export_csv.csv')
{

   $conn = dbConnection();
// Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }
    $sql_query = "SELECT id, firstname, lastname FROM MyGuests";

    // Gets the data from the database
    $result = $conn->query($sql_query);

    $f = fopen('php://temp', 'wt');
    $first = true;
    while ($row = $result->fetch_assoc()) {
        if ($first) {
            fputcsv($f, array_keys($row));
            $first = false;
        }
        fputcsv($f, $row);
    } // end while

    $conn->close();

    $size = ftell($f);
    rewind($f);

    header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
    header("Content-Length: $size");
    // Output to browser with appropriate mime type, you choose ;)
    header("Content-type: text/x-csv");
    header("Content-type: text/csv");
    header("Content-type: application/csv");
    header("Content-Disposition: attachment; filename=$filename");
    fpassthru($f);
    exit;

}

// db connection function
function dbConnection(){
    $servername = "localhost";
    $username = "root";
    $password = "";
    $dbname = "myDB";
    // Create connection
    $conn = new mysqli($servername, $username, $password, $dbname);
    return $conn;
}


?>

根据新的信息,我将此作为解决方案

<?php

// call export function
exportMysqlToCsv('export_csv.csv');


// export csv
function exportMysqlToCsv($filename = 'export_csv.csv')
{

   $conn = dbConnection();
// Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }
    $sql_query = "SELECT id, firstname, lastname FROM MyGuests";

    // Gets the data from the database
    $result = $conn->query($sql_query);

    $f = fopen('php://temp', 'wt');
    $first = true;
    while ($row = $result->fetch_assoc()) {
        if ($first) {
            fputcsv($f, array_keys($row));
            $first = false;
        }
        fputcsv($f, $row);
    } // end while

    $conn->close();

    $size = ftell($f);
    rewind($f);

    header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
    header("Content-Length: $size");
    // Output to browser with appropriate mime type, you choose ;)
    header("Content-type: text/x-csv");
    header("Content-type: text/csv");
    header("Content-type: application/csv");
    header("Content-Disposition: attachment; filename=$filename");
    fpassthru($f);
    exit;

}

// db connection function
function dbConnection(){
    $servername = "localhost";
    $username = "root";
    $password = "";
    $dbname = "myDB";
    // Create connection
    $conn = new mysqli($servername, $username, $password, $dbname);
    return $conn;
}


?>

您能指出您认为逗号分隔值写入文件的代码行吗?反问句。一个简单的csv行看起来像34,johndoe,而您的代码打印的是id:34-Name:johndoe。因此,至少您必须告诉导入应用程序使用-作为分隔符;但我怀疑结果是否是你想要的。您可能对另一个用户询问如何将MySQL数据转换为csv文件感兴趣。看看这里,我相信这会让你走上正轨:在表格中,巫婆的名字被划分为:,.-/表中的单词用、.-;/请删除。您能指出您认为逗号分隔值写入文件的代码行吗?反问句。一个简单的csv行看起来像34,johndoe,而您的代码打印的是id:34-Name:johndoe。因此,至少您必须告诉导入应用程序使用-作为分隔符;但我怀疑结果是否是你想要的。您可能对另一个用户询问如何将MySQL数据转换为csv文件感兴趣。看看这里,我相信这会让你走上正轨:在表格中,巫婆的名字被划分为:,.-/表中的单词用、.-;/请删除。我是错误:注意:尝试在C:\xampp\htdocs\export\u csv\export\u csv.php的第19行0 results中获取非对象的属性我将所有内容导出到一列中。您可以在这里看到:我想确认该表包含:,.;-/:事实上,这很好,看看附件中的这个例子,这取决于你用什么程序打开文件。事实上,由于它们是逗号分隔的,因此计算机程序可以将其作为有效的csv读取。您可以查看是否可以添加一些格式。看这个例子:它不好。id、firstName和lastName是表头。id->A1;名字->B1;lastname->c1哦,根据我重做函数的新信息,这不是您最初的帖子所做的。我是错误的:注意:试图在第19行0结果中获取C:\xampp\htdocs\export\u csv\export\u csv.php中的非对象属性。我在一列中导出所有内容。您可以在这里看到:我想确认该表包含:,.;-/:事实上,这很好,看看附件中的这个例子,这取决于你用什么程序打开文件。事实上,由于它们是逗号分隔的,因此计算机程序可以将其作为有效的csv读取。您可以查看是否可以添加一些格式。看这个例子:它不好。id、firstName和lastName是表头。id->A1;名字->B1;lastname->c1哦,根据我重做的新信息,这不是你最初的帖子所做的。