博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
将CSV数据导入到数据库
阅读量:6248 次
发布时间:2019-06-22

本文共 2053 字,大约阅读时间需要 6 分钟。

hot3.png

  1. 将数据库中的文件导出成csv文件:

    select company,currenttime,description from mydata into outfile 'i://1.csv' fields terminated by ','optionally enclosed by ''lines terminated by '/n';

    备注:

    csv(Comma-Separated Values,逗号分隔值),是一种有一定格式(用指定符号分隔)的文本文件(文本文件本来是没有格式的)。

 

2. 一条sql语句可以插入多条记录:

  INSERT INTO mydata(company,currenttime,description) VALUES('公司一','2014-04-07 12:23:34','公司已描述'),('公司二','2014-04-07 12:23:34','公司二描述')

 

3.开始实现数据导入(基于ThinkPHP框架);

  (1).HTML页面源代码:

        <form action="{:U('Index/importData')}"  METHOD="POST"  ENCTYPE="multipart/form-data" >

                <label for="import"><input type="file"  name="summary" /></label>  </br></br></br></br>
                <input type="submit" value="开始导入" />
            </form>

 

(2).控制器: 

//显示模板

    public function index(){
        $this->display();
    }
   
    //数据导入
    public function importData(){
       
        $upload = new \Think\Upload();
        $upload ->exts=array('csv','xls','xlsx');//暂时支持了Excel等格式,为了测试
        $upload ->rootPath='./Uploads/';//设置文件上传的根路径
        $upload ->savePath="";//设置文件上传子路径
       
        $info=$upload->upload();
       
        //上传错误提示错误信息
        if(!$info) $this->error($upload->getError());

        //开始读取对应的文件

        $file=$upload->rootPath.$upload->savePath.$info['summary']['savepath'].$info['summary']['savename'];
       
        //如果文件存在,开始拆分拆分数据,进行导入操作
        if(!file_exists($file)){
            $this->error("上传的文件丢失,请重新上传!");
        }
       
        //文件存在,开始导入
        $str_content = file_get_contents($file); //将所有的记录获取成一个字符串
        $arr_content = explode('/n', $str_content); //将字符串形式的所有记录拆分成数组
        $sum_content = count($arr_content) - 1; //380

        $sql = "INSERT INTO mydata(company,currenttime,description) VALUES";

        foreach ($arr_content as $k1 => $v1) {
            if ($k1 < $sum_content) {
                $arr_list = explode(',', $v1);
                $sum_list = count($arr_list); //3

                $sql .= "(";

                foreach ($arr_list as $k2 => $v2) { //字段
                    if ($k2 < $sum_list - 1) {
                        $sql .= "'" . $v2 . "'" . ',';
                    } else {
                        $sql .= "'" . $v2 . "'";
                    }
                }
                $sql .= "),";
            }
        }

        $model = new \Think\Model(); //

        $result = $model->execute(rtrim($sql, ","));

        $spend_time=round(microtime(true)-$GLOBALS['_beginTime'],4);

    
        if ($result) {
            $this->success("成功插入".$reuslt."条数据,共耗时".$spend_time."s");
        } else {
            $this->error('插入失败,请重试!');
        }
     
    }

 

转载于:https://my.oschina.net/u/1771585/blog/661438

你可能感兴趣的文章
Python Day30
查看>>
WebRequest对DNS说:没有你我依然可以
查看>>
jvm垃圾收集小记
查看>>
MonthCalendar的mousedown方法选择日期
查看>>
用于pytorch的H5Dataset接口(类比TensorDataset接口)
查看>>
Python-入门第三篇
查看>>
解决Cannot change version of project facet Dynamic Web M
查看>>
mysql备份与恢复
查看>>
hadoop实例sort
查看>>
jstat (JVM统计监测工具)
查看>>
git 免密码push,pull
查看>>
js懒加载
查看>>
计算某时间是年中第几周。
查看>>
【论文阅读】A mixed-scale dense convolutional neural network for image analysis
查看>>
用正则表达式匹配网址URL中最后一个反斜杠/后面的内容
查看>>
Define custom @Required-style annotation in Spring
查看>>
General: Know How to Use InetAddress
查看>>
php 克隆和引用类
查看>>
Linux编程之变量
查看>>
weblogic的下载安装及myeclipse的配置
查看>>