spreadJs导入、Java保存到数据库
下载并引用spreadJs
定义全局变量,初始化表格控件 var $this = this;this.spread_obj;
- $this.spread_obj = new GC.Spread.Sheets.Workbook(document.getElementById('xxx'));
- function fn_import() {
- var lay = layer.open({
- type: 5,
- title: '导入文件',
- closeBtn: true,
- area: ['350px', 'auto'],
- btn: ['保存', '取消'],
- btnAlign: 'c',
- scrollbar: false,
- moveType: 1,
- content: ' <input type="file" id="fileDemo" class="input"',
- success: function(e, index) {
- },
- yes: function(index, layero) {
- var files = $('#fileDemo').val();
- var suffix = files.substring(files.lastIndexOf(".") + 1, files.length);
- if (suffix == "xls" || suffix == "xlsx") {
- var excelFile = document.getElementById('fileDemo').files[0];
- var tempSpread = $this.spread_obj;
- var excelIO = new GC.Spread.Excel.IO();
- excelIO.open(excelFile, function(json) {
- tempSpread.fromJSON(
- json, {
- ignoreFormula: false,
- ignoreStyle: false,
- frozenColumnsAsRowHeaders: false,
- frozenRowsAsColumnHeaders: false
- }
- );
- layer.close(lay);
- }, function(e) {
- // process error
- console.log(e);
- });
- } else {
- layer.msg("请选择excel文件!");
- }
- }
- });
- }
- function fn_save_add(callback) {
- var template_property = escape(
- JSON.stringify(
- $this.spread_obj.toJSON({
- //includeBindingSource: true,
- ignoreStyle: false,
- ignoreFormula: false,
- rowHeadersAsFrozenColumns: false,
- columnHeadersAsFrozenRows: false
- })
- )
- );
- $.ajax({
- type: "POST",
- url: panchina.spreadjs.common.url() + "/system/api/template/v1/addTemplate",
- contentType: "application/json;charset=UTF-8",
- data: JSON.stringify(template_property),
- xhrFields: {
- withCredentials: true
- },
- success: function(result) {
- layer.close(index);
- if (result.code == 200) {
- layer.msg("保存成功", {
- time: 2000,
- icon: 1
- });
- } else {
- console.log(result);
- if (result.message) {
- layer.msg("保存失败:" + result.message, {
- time: 4000,
- icon: 2
- });
- } else {
- layer.msg("保存失败:" + result.msg, {
- time: 4000,
- icon: 2
- });
- }
- }
- },
- error: function(xhr, msg, ex) {}
- });
- }
- //controller文件
- //保存新增调查表模板数据
- @PostMapping("/v1/addTemplate")
- @ApiOperation(value = "保存新增调查表模板数据")
- public ApiResult addTemplate(@RequestBody QuestionaryTemplateVO query) {
- return templateService.addTemplate(query);
- }
- //service文件
- @Override
- @Transactional(rollbackFor = Exception.class)
- public ApiResult addTemplate(QuestionaryTemplateVO query) {
- //模板编号不能重复
- Long existId = questionaryTemplateMapperExt.getTemplateByTemplateCode(query.getTemplate().getCode());
- if (existId != null) {
- return ApiResult.error("模板编码已存在");
- }
- Map map = new HashMap();
- try {
- query.getData().setId(PrimaryKeyUtil.getPrimaryKeyId());
- query.getData().setTemplateId(query.getTemplate().getId());
- //模板数据解码
- query.getData().setTemplateData(ConvertFormUtil.unescape(query.getData().getTemplateData()));
- questionaryTemplateDataMapper.insert(query.getData());
- map.put("templateId", query.getTemplate().getId());
- } catch (InvalidSystemClockException e) {
- throw new CustomException(400, "主键生成异常");
- }
- return ApiResult.ok(map);
- }
- //util文件
- public class ConvertFormUtil {
- //存在中文乱码问题
- public static String ConvertForm(String convertStr) {
- String str = convertStr.replaceAll("%(?![0-9a-fA-F]{2})", "%25");
- return URLDecoder.decode(str);
- }
- public static String unescape(String src) {
- StringBuffer tmp = new StringBuffer();
- tmp.ensureCapacity(src.length());
- int lastPos = 0, pos = 0;
- char ch;
- while (lastPos < src.length()) {
- pos = src.indexOf("%", lastPos);
- if (pos == lastPos) {
- if (src.charAt(pos + 1) == 'u') {
- ch = (char) Integer.parseInt(src
- .substring(pos + 2, pos + 6), 16);
- tmp.append(ch);
- lastPos = pos + 6;
- } else {
- ch = (char) Integer.parseInt(src
- .substring(pos + 1, pos + 3), 16);
- tmp.append(ch);
- lastPos = pos + 3;
- }
- } else {
- if (pos == -1) {
- tmp.append(src.substring(lastPos));
- lastPos = src.length();
- } else {
- tmp.append(src.substring(lastPos, pos));
- lastPos = pos;
- }
- }
- }
- return tmp.toString();
- }
- }
注:MySQL根据配置文件会限制Server接受的数据包大小。有时候插入、更新或查询时数据包的大小,会受 max_allowed_packet 参数限制,导致操作失败。
show VARIABLES
like
'%max_allowed_packet%'
;查看
set
global
max_allowed_packet = 20*1024*1024*10 ;修改
spreadJs导入、Java保存到数据库的更多相关文章
- 解决Java保存到数据库中文乱码问题,加useUnicode=true&characterEncoding=UTF-8
Java保存到数据库中文乱码, 解决方法如下: 我们在连接MySQL数据库的时候一般都会在url后面添加useUnicode=true&characterEncoding=UTF-8,但是问什 ...
- Java导入excel并保存到数据库
首先建立好excel表格,并对应excel表格创建数据库表. 前台jsp页面:其中包含js <%@ page language="java" import="jav ...
- POI读取Excel数据保存到数据库,并反馈给用户处理信息(导入带模板的数据)
今天遇到这么一个需求,将课程信息以Excel的形式导入数据库,并且课程编号再数据库中不能重复,也就是我们需要先读取Excel提取信息之后保存到数据库,并将处理的信息反馈给用户.于是想到了POI读取文件 ...
- JAVA从文本文件(txt)读取一百万条数据保存到数据库
Java读取大文本文件保存到数据库 1.追求效率 将文件读取到内存,效率比较高,经过测试读取1G左右的文本文件,机器内存消耗达到接近3个G,对内存消耗太大,不建议使用 2.通过调用第三方类库实现 通过 ...
- Java 用jxl读取excel并保存到数据库(此方法存在局限,仅限本地电脑操作,放在服务器上的项目,需要把文件上传到服务器,详细信息,见我的别的博客)
项目中涉及到读取excel中的数据,保存到数据库中,用jxl做起来比较简单. 基本的思路: 把excel放到固定盘里,然后前段页面选择文件,把文件的名字传到后台,再利用jxl进行数据读取,把读取到的数 ...
- Java实现MySQL数据库导入
距离上班还有一段时间.现在总结一下如何使用Java语言实现MySQL数据库导入: 首先新建名为test的数据库: 其次执行下面Java代码: import java.io.File; import j ...
- 利用Java进行MySql数据库的导入和导出
利用Java来进行Mysql数据库的导入和导出的总体思想是通过Java来调用命令窗口执行相应的命令. MySql导出数据库的命令如下: mysqldump -uusername -ppassword ...
- Java Hour 47 WeatherInfo 保存到数据库
经历了上周简单的休整以后,我们继续Hibernate 之旅. 保存到数据库 private void saveWeatherInfo(Weatherinfo weatherInfo) { // Sav ...
- Java读取oracle数据库中blob字段数据文件保存到本地文件(转载)
转自:https://www.cnblogs.com/forever2698/p/4747349.html package com.bo.test; import java.io.FileOutput ...
- Java中将图片保存到数据库中
在实际的开发中,我们可能需要将图片.影音等文件直接保存到数据库中,然后通过编程方式将数据读出进行使用.例如将读出的图片数据显示出来,将读出的电影文件播放出来. 二进制数据直接保存到文件和从文件中读出非 ...
随机推荐
- 微服务笔记之Euraka(2)
Eureka Server启动过程 入口:SpringCloud充分利用了SpringBoot的自动装配的特点 Eureka-server的jar包,发现在MERA-INF下面有配置文件spring. ...
- 宿主机通过vmware创建的kali虚拟机连接redis,sftp等功能
介绍 黑客专用的linux kali, 下载后即包含很多黑客工具,对于我这样的菜鸡,很感动的就是里面包含了最新版的redis,java,mysql等工具.自带不错的界面省事 kali官网: https ...
- idea启动项目,报java.lang.OutOfMemoryError: PermGen space 和启动项目很慢的问题解决
启动一个老的项目,报错,查是内存溢出 进入 VM options 加上 -Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m 在 ...
- Account Manager privacy agreement
Account Manager privacy agreement [Account Manager] (hereinafter referred to as "we") )We ...
- 在百度云服务器上部署Django网站的经历
前言: 前段时间,利用Django为单位制作了一个小型的内部考勤系统,本想放到单位内部的服务器上,考虑到运行的稳定.安全防护等问题,最终决定把网站部署到百度云服务器上,事先也在网上查找了一些资料,但过 ...
- vue自定义组件的总结(一)
1.定义组件时 <template> <input class="input" :type="type" :pla ...
- SQL语句大全,你不会写的SQL可能都在这里
1.创建数据库 CREATE DATABASE database-name 2.删除数据库 drop database dbname3.说明:备份sql server 创建 备份数据的 device ...
- 查看oracle死锁
select A.sid, b.serial#, decode(A.type, 'MR', 'Media Recovery', 'RT','Redo Thread', 'UN','User Name' ...
- 福昕PDF如何以多个窗口打开文件
福昕PDF默认设置下双击打开多个文件,所有文件只会在同一个程序内显示,怎样让每个文件都使用单独一个程序,以多个窗口的形式打开呢? 福昕软件,文件 > 偏好设置 > 文档 > 勾选&q ...
- Django的urls的配置
在一个请求到达的时候,最先达到的就是视图层,然后根据url映射到视图函数.这一部分我们来说明url的配置. 概述 为了给一个应用设计URL,你需要创建一个Python 模块,通常称为URLconf(U ...