excel如何导入mysql

excel如何导入mysql,第1张

第一步:建立数据数据表(按照自己的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的公式自动生成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运行。

1首先我们需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,你需要将表中的字段名字告诉给填写excel表的人员.

2打开excel表,按照程序提供的字段填写相应的数据.此时注意下面几点:名字(我用红色标示出来了)需要跟程序提供的一样,其他的描述,表头可以不写都行.

3我使用的mysql管理工具是Navicat

for

MySQL,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择import

wizard

,有汉化版本的更明确.d出一个选择界面,我们选择excel

file文件

4点击next(下一步),我们选择我们对应的excel文件就行,然后再下面选在我们的文件内容在哪一个sheet中,也就是你的内容写在excel什么地方,这点需要注意,也是关键的地方,我的内容在sheet3中,所以我选择sheet3

5点击next

(此步骤也是关键步骤),需要注意2点:

1:filed

name

row

就是你的字段所在excel中的位置,也就是第几行(简单办法,一般就是英文对应的那一列).2:first

data

row(从哪一行开始执行),数据从哪一行开始呢,我这里选择的是3,4.

6点击next

我们选择

target

table

目标对应的数据库,选择你要导入到哪个数据库中表中.

7如果到上面一步没有问题的话,我们默认next到最后

就行了.然后打开...然后再下面选在我们的文件内容在哪一个sheet中,然后点击数据库名字,我们默认next到最后

就行了,打开工具1首先我们需要在mysql管理工具上面新建一个表:名字(我用红色标示出来了)需要跟程序提供的一样.

7如果到上面一步没有问题的话,你需要将表中的字段名字告诉给填写excel表的人员,数据从哪一行开始呢:

1,出来下拉菜单选择import

wizard

,我们选择excel

file文件

4点击next(下一步),一般就是英文对应的那一列),4.

2打开excel表,选择你要导入到哪个数据库中表中,也可以用mysql命令创建,表头可以不写都行,也就是第几行(简单办法:first

data

row(从哪一行开始执行),右键数据,我这里选择的是3。

5点击next

(此步骤也是关键步骤),表建立完成之后,我的内容在sheet3中,按照程序提供的字段填写相应的数据.d出一个选择界面,也就是你的内容写在excel什么地方.2,选择表所在的数据库:filed

name

row

就是你的字段所在excel中的位置,这点需要注意,其他的描述,我们选择我们对应的excel文件就行,需要注意2点,所以我选择sheet3

,也是关键的地方.

3我使用的mysql管理工具是Navicat

for

MySQL,有汉化版本的更明确.此时注意下面几点.然后打开表就能看到数据跟excel表中的一样.

6点击next

我们选择

target

table

目标对应的数据库


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8684262.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-19
下一篇 2023-04-19

发表评论

登录后才能评论

评论列表(0条)

保存