mysql 与 xls 连接_数据库MySQL与xls文件的互导

最近的一个项目需要将xls表导入到MySQL数据库中和将MySQL数据表导出到xls表中,在网上搜了很多资料,经过多次尝试终于实现了功能,废话不多说,在这粘贴出代码,希望可以帮到需要的朋友。

一、将.xls表导入到MySQL数据表中。

这里我用的是一个类库,下载地址:http://sourceforge.net/projects/phpexcelreader/  可以这个下载的不能直接使用,要做相应的修改(参照:http://www.cnblogs.com/phpzxh/archive/2009/09/16/1568133.html)。下载以后,我们需要的只是那个Excel文件夹,其他是自带的案例,因为不能运行所以可以删除不管。打开这个Excel文件夹,里面有两个文件,oleread.inc和reader.php,其中这个readre.php是应该包含oleread.inc的,显然下载的是没有,只要改动将其包含进去就可以了。接下来就可以直接使用了,看代码

1 $Import_TmpFile = $_FILES['file']['tmp_name'];2 require_once '../utils/reader.php'; //引入刚才的reader.php3 $data = newSpreadsheet_Excel_Reader();4 $data->setOutputEncoding('UTF-8');5 $data->read($Import_TmpFile);6 //$data是对象数据,将其遍历成数组

7 $array =array();8 for ($i = 1; $i <= $data->sheets[0]['numRows']; $i++) {9 for ($j = 1; $j <= $data->sheets[0]['numCols']; $j++) {10 $array[$i][$j] = $data->sheets[0]['cells'][$i][$j];11 }12 } //这一步就是讲xls文件的内容遍历出来了,是一个数组的形式,下面的就是如何插入数据库了。13 //将数据写入trade交易数据表中

14 $sql = "insert into dou_trade(trade_time,institution,mediacy,trade_account,user_name,goods_type,trade_number,trade_pay,level_benefit,hold_benefit,benefit_total,exchange_poundage,membership_poundage,user_poundage) values(:trade_time,:institution,:mediacy,:trade_account,:user_name,:goods_type,:trade_number,:trade_pay,:level_benefit,:hold_benefit,:benefit_total,:exchange_poundage,:membership_poundage,:user_poundage)";15 $stmt = $pdo->prepare($sql);16 for($i=1;$i<=count($array);$i++){17 $stmt->bindParam(':trade_time', $array[$i]['2']);18 $stmt->bindParam(':institution', $array[$i]['3']);19 $stmt->bindParam(':mediacy', $array[$i]['4']);20 $stmt->bindParam(':trade_account', $array[$i]['5']);21 $stmt->bindParam(':user_name', $array[$i]['6']);22 $stmt->bindParam(':goods_type', $array[$i]['7']);23 $stmt->bindParam(':trade_number', $array[$i]['8']);24 $stmt->bindParam(':trade_pay', $array[$i]['9']);25 $stmt->bindParam(':level_benefit', $array[$i]['10']);26 $stmt->bindParam(':hold_benefit', $array[$i]['11']);27 $stmt->bindParam(':benefit_total', $array[$i]['12']);28 $stmt->bindParam(':exchange_poundage', $array[$i]['13']);29 $stmt->bindParam(':membership_poundage', $array[$i]['14']);30 $stmt->bindParam(':user_poundage', $array[$i]['15']);31 $tag = $stmt->execute();32 }

这样就可以将xls文件的内容导入到数据表中了。

二、将MySQL数据表内容导出到xls表中。

这得益于一篇文章,地址:http://krasimirtsonev.com/blog/article/php-export-mysql-data-to-xls-file。其核心代码如下

1 functionxlsBOF() {2 echo pack("ssssss", 0x809, 0x8, 0x0, 0x10, 0x0, 0x0);3 }4 functionxlsEOF() {5 echo pack("ss", 0x0A, 0x00);6 }7 function xlsWriteNumber($Row, $Col, $Value) {8 echo pack("sssss", 0x203, 14, $Row, $Col, 0x0);9 echo pack("d", $Value);10 }11 function xlsWriteLabel($Row, $Col, $Value) {12 $L = strlen($Value);13 echo pack("ssssss", 0x204, 8 + $L, $Row, $Col, 0x0, $L);14 echo $Value;15 }16 //prepare headers information

17 header("Content-Type: application/force-download");18 header("Content-Type: application/octet-stream");19 header("Content-Type: application/download");20 header("Content-Disposition: attachment; filename=\"export_".date("Y-m-d").".xls\"");21 header("Content-Transfer-Encoding: binary");22 header("Pragma: no-cache");23 header("Expires: 0");24 //start exporting

25 xlsBOF();26 //first row

27 xlsWriteLabel(0, 0, "id");28 xlsWriteLabel(0, 1, "name");29 xlsWriteLabel(0, 2, "email");30 //second row

31 xlsWriteNumber(1, 0, 230);32 xlsWriteLabel(1, 1, "John");33 xlsWriteLabel(1, 2, "john@yahoo.com");34 //third row

35 xlsWriteNumber(2, 0, 350);36 xlsWriteLabel(2, 1, "Mark");37 xlsWriteLabel(2, 2, "mark@yahoo.com");38 //end exporting

39 xlsEOF();

只要将其中的first row /second row等换成表的内容就可以了。其中注意的是是编码问题,数据库中的数utf-8,而xls中式gbk编码的,为防止出现乱码,最好的办法是在写入xls表之前用iconv进行转码就可以了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/556898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例

如何用一条sql语句实现批量更新&#xff1f;mysql并没有提供直接的方法来实现批量更新&#xff0c;但是可以用点小技巧来实现。 代码如下: UPDATE mytable SET myfield CASE id WHEN 1 THEN valueWHEN 2 THEN valueWHEN 3 THEN value END WHERE id IN (1,2,3);这里使用了c…

MySQL可运行在不同的操作系统下_不同操作系统下的mysql数据库同步

当数据库的数据量读写频繁的时候&#xff0c;我们就要考虑把数据库的读写分开&#xff0c;以提高数据库的使用效率&#xff0c;(当然还有其他用处比如&#xff0c;备份数据)&#xff0c;这个时候我们就要用到mysql的一个功能&#xff0c;数据库同步。下面就具体讲一下实现方法。…

@RequestBody和@RequestParam区别

一&#xff1a;RequestBody和RequestParam区别 RequestParam 用来处理Content-Type: 为 application/x-www-form-urlencoded编码的内容。&#xff08;Http协议中&#xff0c;如果不指定Content-Type&#xff0c;则默认传递的参数就是application/x-www-form-urlencoded类型&am…

mysql内置加密函数_MySQL数据库内置加密函数总结

首先&#xff0c;我认识的加密函数有以下几个&#xff1a;password(plainText)&#xff1a;旧版(OLD_PASSWORD())加密后长度16位&#xff0c;新版41位select length(password("123456"))可以用来查看加密后的字符串的长度。这种加密方法依赖数据库&#xff0c;需要保…

Query String Parameters、Form Data、Request Payload的区别

Query String Parameters 当发起一次GET请求时&#xff0c;参数会以url string的形式进行传递。即?后的字符串则为其请求参数&#xff0c;并以&作为分隔符。 如下http请求报文头&#xff1a; GeneralRequest URL: http://login?unamedingdingRequest Method: GETQuery…

c mysql 添加数据类型_MYSQL的常用命令和增删改查语句和数据类型

连接命令&#xff1a;mysql -h[主机地址] -u[用户名] -p[用户密码]创建数据库&#xff1a;create database [库名]显示所有数据库: show databases;打开数据库:use [库名]当前选择的库状态:SELECT DATABASE();创建数据表:CREATE TABLE [表名]([字段名] [字段类型]([字段要求]) …

@requestbody和@requestparam作用

1、什么都不写 GET 可以自动封装为对象模型&#xff0c;没有的数值自动为0值 POST 请求体里面放了数据&#xff0c;但是还是使用了RequestParam里的数据 总结&#xff1a; 在不使用注解的情况下&#xff0c;相当于默认使用了RequestParam里的数据 &#xff08;这种理解是错…

@RequestBody的使用

提示&#xff1a;建议一定要看后面的RequestBody的核心逻辑源码以及六个重要结论本文前半部分的内容都是一些基 本知识常识&#xff0c;可选择性跳过。 声明&#xff1a;本文是基于SpringBoot&#xff0c;进行的演示说明。 基础知识介绍&#xff1a; ​ RequestBody主要用来接…

mysql 字段值为 a b c_数据的虚拟列-让数据库中的C字段等于a+b

直接用update aaaaa aa set aa.f (aa.aaa.b)就行了引出来的新知识--虚拟列虚拟列的好处是:如果cab那插入数据时&#xff1b;值只插入a1,b2;那么c会自动是3oracle temporary table and virtual column(2013-07-31 15:06:55)表是数据库中保存用户数据最基本的结构。下面我简要的…

@RequestBody 和 @RequestParam可以同时使用

RequestParam和RequestBody这两个注解是可以同时使用的。 网上有很多博客说RequestParam 和RequestBody不能同时使用&#xff0c;这是错误的。根据HTTP协议&#xff0c;并没有说post请求不能带URL参数&#xff0c;经验证往一个带有参数的URL发送post请求也是可以成功的。只不过…

mysql索引使增删变慢_mysql优化之索引篇

mysql&#xff0c;对it打工人&#xff0c;这个几乎是必备的技能之一。mysql可以解决我们平时工作中的大量的、有关增删查改的问题。所以想深入了解mysql&#xff0c;我觉得关键在于他的增删查改背后的算法&#xff0c;开搞。面对增删查改等问题&#xff0c;直接通过场景来看吧场…

POST、GET、@RequestBody和@RequestParam区别

RequestParam 注解RequestParam接收的参数是来自HTTP请求体或请求url的QueryString中。 RequestParam可以接受简单类型的属性&#xff0c;也可以接受对象类型。 RequestParam有三个配置参数&#xff1a; required 表示是否必须&#xff0c;默认为 true&#xff0c;必须。de…

python与linux关系_如何处理Linux / Python依赖关系?

由于缺乏对我想使用的一些库的支持,我将一些Python开发从Windows转移到Linux开发.我已经花了大部分时间搞乱了依赖关系.问题每当我拿起Linux,我通常会遇到一些依赖问题,通常是开发库,无论是通过apt-get,easy_install或pip安装.我可以浪费时间,应该是简单的任务,花更长的时间让图…

Springmvc接收json数据的4种方式

1、以RequestParam接收 前端传来的是json数据不多时&#xff1a;[id:id],可以直接用RequestParam来获取值 Autowired private AccomodationService accomodationService;RequestMapping(value "/update") ResponseBody public String updateAttr(RequestParam (&q…

centos安装mysql卡住_CentOS 6.4安装MySQL的过程中出现的bug

在CentOS 6.4下安装MySQL&#xff0c;下载一个源码包&#xff0c;感觉很简单&#xff0c;tar&#xff0c;./configure&#xff0c;make&#xff0c;make install 经典四步&#xff0c;弄这个也不是第一次了&#xff0c;但今天就是老出错&#xff0c;首先是./configure中&#x…

SpringMVC接受List的几种方式

说到SpringMVC接受List参数&#xff0c;可能有人会说这个是个坑&#xff01;下面我来跟大家说怎么补这个坑。下面我分几种情况来讲&#xff1a; 一、只接收一个List 1、form表单提交 controller代码&#xff1a; ResponseBody RequestMapping("test") public voi…

mysql怎么加固_mysql安装及加固

mysql安装查看是否安装mysql我们先看一下有没有安装mysqlyum list installed mysql | grep mysql本地只安装了php链接mysql的库&#xff0c;没有安装mysql如果有安装&#xff0c;可以使用安装的或者卸载了重新安装添加yum源去mysql官网查找下面我就来安装下yum源sudo rpm -ivh …

python标准库os的方法listdir_使用python标准库快速修改文件名字

大家在追剧的时候会一次性下载很多电影&#xff0c;但是很烦人的是前面会有很多电影网站的广告前缀。今天我将介绍一个简短的代码&#xff0c;快速修改这些文件的名字。工具&#xff1a;os首先在电影目录下新建一个py文件&#xff0c;并导入osimport osos&#xff0c;是python中…

RabbitMQ保姆级教程

文章目录 前言一、MQ是什么&#xff1f; 1.1 AMQP 二、在Linux安装RabbitMQ 2.1 安装2.2 RabbitMQ启动命令2.3 开启RabbitMQ 后台管理界面 2.3.1 登录rabbitMQ UI界面 2.3 Docker启动RabbitMQ2.4 常见消息模型2.5 生产者(Producer) / 消费者(Consumer)2.6 工作队列模式(Work Q…

spring mysql 连接池配置_SpringBoot数据库连接池常用配置

关注公众号&#xff1a;程序猿王国 持续更新&#xff0c;每日分享在配置文件中添加配置如下(我使用的是多数据源)&#xff1a;spring.datasource.primary.urljdbc\:mysql\://localhost\:3306/test?useUnicode\true&characterEncoding\utf-8spring.datasource.prim…