溜溜问答 > 日常办公 > Excel > 如何将Excel的数据导入到mysql数据库中?
高傑西
高傑西
邀请你来回答
51人阅读 2022-03-22

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

我要回答
2个回答

第一步:建立数据库和数据表(按照自己的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?




phpexcel导入excel数据到MYSQL数据库










第三步:向数据库插入数据的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."
";
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."条数据!!!
";
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数据库完成。

查看全部
2022-03-22
回复 采纳

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运行。

查看全部
2022-03-22
(2) 回复 采纳

相关问题

如何将Excel中的数据导入mysql数据库?
共3条回答 >
秦向阳: 方法/步骤首先我们需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,你需要将表中的字段名字告诉给填写Excel表的人员.打开Excel表,按照程序提供的字段填写相应的数据.此时注意下面几点:名字(我用红色标示出来了)需要跟程序提供的一样,其他的描述,表头可以不写都行.我使用的mysql管理工具是navicatFormysql,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择importwizard,有汉化版本的更明确.弹出一个选择界面....
(1) 回复
如何将Excel导入mysql数据库?
共1条回答 >
闷油瓶: 首先我们需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,你需要将表中的字段名字告诉给填写Excel表的人员.打开Excel表,按照程序提供的字段填写相应的数据.此时注意下面几点:名字(我用红色标示出来了)需要跟程序提供的一样,其他的描述,表头可以不写都行.我使用的mysql管理工具是navicatFormysql,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择importwizard,有汉化版本的更明确.弹出一个选择界面,我们选择....
(1) 回复
如何将Excel数据导入mysql数据库?
共1条回答 >
阿巽: F1:生成TXT文件1.将文件另存为“文本文件(制表符分割)(*.txt)”2.然后进入命令提示符里使用命令loaddatalocalinfiledata.txtintotableexceltomysqlfieldsterminatedby'\t';数据从MySql到Excel的转化,其过程其实还是借助那个“制表符分割”的文本文件。将如要将这个表中的男生信息导入到Excel中,可以这样。select*intooutfiledata.txt'fromexceltom....
(1) 回复
如何将Excel表格中数据直接导入到mysql数据库中?
共1条回答 >
Sa²: 首先需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,需要将表中的字段名字告诉给填写excel表的人员.打开excel表,按照程序提供的字段填写相应的数据.此时注意下面几点:名字需要跟程序提供的一样,其他的描述,表头可以不写都行.打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择importwizard.弹出一个选择界面,选择excelfile文件点击next(下一步),选择对应的excel文件就行,然后再下面选在文件内容在哪一个she....
回复
如何把Excel数据导入到mysql数据库中?
共1条回答 >
莫不烦: 工具/原料MySQL-Front5.3MySQL5.0BasicCode.xls方法/步骤第一步:使用MySQL-Front5.3访问数据库,打开数据界面如下第二步,新建表,tb_test字段最好和保持数据一致第三步,要导入的Excel数据,格式如下第四步,选中新建的表右键,然后点击"MSexcel文件(M)...",在选中要导入的Excel文件。第五、选中要导入的数据,以下截图中显示的是excel文件中的sheet名称,点击下一步,然后将excel表中的数据项和数据库表中的字段一一对应,点击下....
回复
发表成功!
感谢您的分享!
好的
官方微信群

(微信添加“妙妙”或“笑笑”,邀您进群)