打开MySQL数据库,然后在在MySQL中新建一个【student】表,创建列为ID和Name,如下图所示:
Excel新建一张Excel,Excel列中的名字要与数据库中student的列名一样,如下图所示:
导入向导右击数据库中的【student】表,在d出的下拉菜单中选择【导入向导】,如下图所示:
选择数据格式会d出一个【导入向导】窗口,选择数据的格式,比如excel的格式为.xlsx,当然有的excel的格式为.xls,根据后缀名而定,如下图所示:
导入excel然后要导入方才新建的excel文件,选择文件的存放位置,然后点击【打开】按钮即可,如下图所示:
选择sheet然后选择要导入excel文件中的哪一个sheet,比如选择sheet1,然后点击【下一步】按钮,如下图所示:
导入模式然后一直点击【下一步】按钮来到【导入模式】,勾选【添加:添加记录到目录表】选项,点击【下一步】按钮,如下图所示:
开始导入点击【开始】按钮,当出现【Finished -Successfully】提示时即表示导入成功,如下图所示:
第一步:建立数据库和数据表(按照自己的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/htmlcharset=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/htmlcharset: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数据库完成。
如何将excel表格的数据导入到mysql数据中去步骤:
1、打开mysql,用mysql命令创建一个表。
2、打开office excel,按照程序提供的字段填写相应的数据。
3、打开mysql管理工具,择表所在的数据库,点击数据库名字,右键数据,选择import wizard,选择excel file文件。
4、点击next,选择对应的excel文件,选择有文字内容的sheet,点击next 。
5、filed name row 就是字段所在excel中的位置,也就是第几行。first data row数据从哪一行开始。填完点击next。
6、选择 target table 目标对应的数据库,选择要导入到的数据库表中。
7、默认next到最后。完成。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)