如何将Excel的数据导入到MySql数据库中
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何将Excel的数据导入到MySql数据库中相关的知识,希望对你有一定的参考价值。
1.使用phpExcel 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数据库中的主要内容,如果未能解决你的问题,请参考以下文章