如何将Excel的数据导入到MySql数据库中

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何将Excel的数据导入到MySql数据库中相关的知识,希望对你有一定的参考价值。

1.使用php
Excel Parser Pro软件,但是这个软件为收费软件;

2.可将EXCEL表保存为CSV格式,然后通过phpmyadmin或者SQLyog导入,SQLyog导入的方法为:
·将EXCEL表另存为CSV形式;
·打开SQLyog,对要导入的表格右击,点击“导入”-“导入使用加载本地CSV数据”;
·在弹出的对话框中,点击“改变..”,把选择“填写excel友好值”,点击确定;
·在“从文件导入”中选择要导入的CSV文件路径,点击“导入”即可导入数据到表上;

3.一个比较笨的手工方法,就是先利用excel生成sql语句,然后再到mysql中运行,这种方法适用于excel表格导入到各类sql数据库:
·假设你的表格有A、B、C三列数据,希望导入到你的数据库中表格tablename,对应的字段分别是col1、col2、col3
·在你的表格中增加一列,利用excel的公式自动生成sql语句,具体方法如下:
1)增加一列(假设是D列)
2)在第一行的D列,就是D1中输入公式:
=CONCATENATE("insert into tablename (col1,col2,col3) values (",A1,",",B1,",",C1,");")
3)此时D1已经生成了如下的sql语句:
insert into table (col1,col2,col3) values ('a','11','33');
4)将D1的公式复制到所有行的D列(就是用鼠标点住D1单元格的右下角一直拖拽下去啦)
5)此时D列已经生成了所有的sql语句
6)把D列复制到一个纯文本文件中,假设为sql.txt
·把sql.txt放到数据库中运行即可,你可以用命令行导入,也可以用phpadmin运行。
参考技术A 第一步:建立数据库和数据表(按照自己的Excel数据设立字段)。
[sql] view plain copy print?
CREATE DATABASE php_excel;
USE php_excel;
CREATE TABLE IF NOT EXISTS php_excel(
id int(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
gid varchar(20) NOT NULL,
stu_no varchar(20) NOT NULL,
name varchar(45) NOT NULL,
age int(4) NOT NULL
)ENGINE=MyISAM DEFAULT CHARSET=utf8;

第二步:前台index.php文件。
[html] view plain copy print?
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>phpexcel导入excel数据到MYSQL数据库</title>
</head>

<body>
<form name="frm1" action="insertdb.php" method="post" enctype="multipart/form-data">
<input name="filename" type="file" />
<input name="submit" type="submit" value="import" />
</form>
</body>
</html>

第三步:向数据库插入数据的insertdb.php文件。
[php] view plain copy print?
session_start();
header("Content-type:text/html;charset:utf-8");
//全局变量

$succ_result=0;
$error_result=0;
$file=$_FILES['filename'];
$max_size="2000000"; //最大文件限制(单位:byte)
$fname=$file['name'];
$ftype=strtolower(substr(strrchr($fname,'.'),1));
//文件格式
$uploadfile=$file['tmp_name'];
if($_SERVER['REQUEST_METHOD']=='POST')
if(is_uploaded_file($uploadfile))
if($file['size']>$max_size)
echo "Import file is too large";
exit;

if($ftype!='xls')
echo "Import file type is error";
exit;

else
echo "The file is not empty!";
exit;


require("./conn.php"); //连接mysql数据库

//调用phpexcel类库
require_once 'PHPExcel.php';
require_once 'PHPExcel\IOFactory.php';
require_once 'PHPExcel\Reader\Excel5.php';

$objReader = PHPExcel_IOFactory::createReader('Excel5');//use excel2007 for 2007 format
$objPHPExcel = $objReader->load($uploadfile);
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); // 取得总行数
$highestColumn = $sheet->getHighestColumn(); // 取得总列数
$arr_result=array();
$strs=array();

for($j=2;$j<=$highestRow;$j++)

unset($arr_result);
unset($strs);
for($k='A';$k<= $highestColumn;$k++)

//读取单元格
$arr_result .= $objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue().',';

$strs=explode(",",$arr_result);
$sql="insert into php_excel(gid,stu_no,name,age) values ($strs[0],'$strs[1]','$strs[2]',$strs[3])";
echo $sql."<br/>";
mysql_query("set names utf8");
$result=mysql_query($sql) or die("执行错误");

$insert_num=mysql_affected_rows();
if($insert_num>0)
$succ_result+=1;
else
$error_result+=1;



echo "插入成功".$succ_result."条数据!!!<br>";
echo "插入失败".$error_result."条数据!!!";

其中conn.php代码如下:
[php] view plain copy print?
$mysql=mysql_connect("localhost","root","") or die("数据库连接失败!");
mysql_select_db("php_excel",$mysql);
mysql_query("set names utf8");

我的导入效果如下:
至此,从Excel文件读取数据批量导入到Mysql数据库完成。
参考技术B 将Excel的数据导入到MySql数据库中方法详见:http://jingyan.baidu.com/article/fc07f9891cb56412ffe5199a.html

如何使用 PHP 将大型 Excel 文件导入 MySql 数据库

【中文标题】如何使用 PHP 将大型 Excel 文件导入 MySql 数据库【英文标题】:How To Import Large Excel File To MySql Database Using PHP 【发布时间】:2014-07-15 04:54:57 【问题描述】:

我必须使用 php 将 excel 文件的数据上传到 MySQL 数据库。我找到了代码,但我无法上传大文件。

谁能告诉我如何增加下面链接中提到的代码的最大文件大小限制:

http://www.9code.in/how-to-import-excel-file-to-mysql-database-using-php/

<!DOCTYPE html>
<?php 
include 'db.php';
include 'Excel/reader.php';
function uploadFile($fieldName, $fileType, $folderName, $name = "")

    $flg = 0;
    $MaxID = "";
    $ext = "";
    $uploadfile = "";
    if (isset($fieldName) AND $fieldName['name'] != '')
    
        $flg = 1;
        $allowed_filetypes = $fileType;
        // I Need to increase this..... I tried changing values but nothing happened
        $max_filesize = 1048576;     
        $filename = $fieldName['name'];
        if ($name == "")
            $MaxID = time() . time() . rand(1, 100);
        else
            $MaxID = $name;
        $ext = substr($filename, strpos($filename, '.'), strlen($filename) - 1);
        if($ext==".xlsx")
            $ext=".xls";
        if (!in_array($ext, $allowed_filetypes))
            echo "<h1>The file you attempted to upload is not allowed...</h1>";
        else if (filesize($fieldName['tmp_name']) > $max_filesize)
            echo "<h1>The file you attempted to upload is too large...</h1>";
        else 
        
            $uploadfile = $folderName . "/" . $MaxID . $ext;
            if (move_uploaded_file($fieldName['tmp_name'], $uploadfile) == FALSE)
            
                echo "<h1>Error in Uploading File...</h1>";
                $MaxID = "";
            
            else
                $MaxID = $MaxID . $ext;
        
    
    return $MaxID;

if(isset($_POST['submit']))

    if($_FILES['csvFile']['name']!="")
    
        $fileName=uploadFile($_FILES['excelFile'],array(".csv"),"excel_file");
        $row=0;
        if(($handle = fopen("excel/".$fileName , "r")) !== FALSE) 
        
            while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) 
            
                $num = count($data);
                //print_r($data);
                $query="INSERT INTO StudentData(FirstName,LastName,MobileNo,City)VALUES('".$data[0]."','".$data[1]."','".$data[2]."','".$data[3]."')";
                mysql_query($query);
            
            fclose($handle);
        
    
    else if($_FILES['excelFile']['name']!="")
    
        $fileName=uploadFile($_FILES['excelFile'],array(".xls",".xlsx"),"excel_file");
        $data = new Spreadsheet_Excel_Reader();
        $data->read('excel_file/'.$fileName);
        for($i=1;$i<=$data->sheets[0]['numRows'];$i++)
        
            $firstname=$data->sheets[0]['cells'][$i][1];
            $lastname=$data->sheets[0]['cells'][$i][2];
            $mobile=$data->sheets[0]['cells'][$i][3];
            $city=$data->sheets[0]['cells'][$i][4];
            $query="INSERT INTO StudentData(FirstName,LastName,MobileNo,City)VALUES('".$firstname."','".$lastname."','".$mobile."','".$city."')";
            mysql_query($query);
        
    

if(isset($_POST['delete']))

    mysql_query("DELETE FROM StudentData");

?>

【问题讨论】:

正如许多人在这里建议的那样,您必须从 php.ini 文件更改帖子大小和上传大小。 【参考方案1】:

您可以在 MySQL 中使用LOAD DATA 命令:Read More

你必须在mysql语句中使用加载数据。这可以将您的大文件加载到数据库中。

mysqli_query($dblink, '
    LOAD DATA LOCAL INFILE "'.$file.'"
        INTO TABLE transactions
        FIELDS TERMINATED by ","
        OPTIONALLY ENCLOSED BY "\'"
        LINES TERMINATED BY "\n"
');

【讨论】:

我无法使用,因为普通用户没有获得太多访问权限...我需要创建一个界面,他们可以从该界面上传来自 excel 的数据 phpmyadmin 中默认上传/导入大小为 2MB。你可以在你的 apache php.ini.try 中增加你的 upload_max_filesize = 20M , post_max_size = 20M 我试过了,但问题依旧 它说:您尝试上传的文件太大...文件名 excel_file/1401167648140116764829 不可读 你能在这里查看代码吗:drive.google.com/file/d/0Bz6rEtX6kxclMFRBa1U1ZkpTWlE/…【参考方案2】:

在你的 php.ini 中查看这些值

upload_max_filesize = 10M post_max_size = 10M

【讨论】:

在我的 php.ini upload_max_filesize = 32M... 但我无法上传超过 1MB 的文件 还要根据 php 的版本检查你的 max_input 时间【参考方案3】:

你需要在你的 php.ini 中设置 upload_max_filesize 和 post_max_size 的值:

; Maximum allowed size for uploaded files.
upload_max_filesize = 40M

; Must be greater than or equal to upload_max_filesize
post_max_size = 40M

我必须补充一点,你必须重新启动服务器

【讨论】:

我照你说的做了,但问题还是一样....我认为源代码需要编辑..您可以在下面的链接中查看源文件..drive.google.com/file/d/0Bz6rEtX6kxclMFRBa1U1ZkpTWlE/… 【参考方案4】:

根据 ASNAOUI Ayoub 我做了以下更改:

; Maximum allowed size for uploaded files.
upload_max_filesize = 40M

; Must be greater than or equal to upload_max_filesize
post_max_size = 40M

但问题还是一样,然后我尝试更改

$max_filesize = 41943040

现在完美运行.....

感谢大家的帮助

【讨论】:

你的意思是 upload_max_filesize = 41943040 吗? 不,不是在 php.ini 我说的是上面代码中使用的变量。 我明白了!您已经谈到了您的 uploadFile() 函数。然后,如果我对 php.ini 进行了上述更改,那么我将能够上传大文件。我说的对吗? 是的...我现在可以上传大文件

以上是关于如何将Excel的数据导入到MySql数据库中的主要内容,如果未能解决你的问题,请参考以下文章

如何将Excel的数据导入到MySql数据库中

如何把EXCEL整理好的数据表直接导入到MYSQL中

如何将EXCEL表导入MYSQL

如何使用 PHP 将大型 Excel 文件导入 MySql 数据库

如何将csv导入mysql和mysql导出csv

laravel 怎么把excel数据导入到数据库中