当前位置: 首页 > news >正文

外贸网站营销方案县级门户网站建设运营成本

外贸网站营销方案,县级门户网站建设运营成本,北京市朝阳区网站开发公司电话,网络科技公司门户网站最近客户有个需求#xff0c;希望在后台增加手动备份功能#xff0c;将数据导出下载保存。 当然#xff0c;此方法不适用于海量数据的备份#xff0c;这只适用于少量数据的sql备份。 这是我生成的sql文件#xff0c;以及sql文件里的insert语句#xff0c;已亲测#x…最近客户有个需求希望在后台增加手动备份功能将数据导出下载保存。 当然此方法不适用于海量数据的备份这只适用于少量数据的sql备份。 这是我生成的sql文件以及sql文件里的insert语句已亲测可以直接执行 项目是SSM框架接下来就展示我的实现代码 首先是接受字段的实体类 Data public class ColumnsDto {/*** 表结构的主要字段**/private String column_name;//该字段则是表字段的数据类型 暂时不需要private String data_type;} 然后是用的到两个主要的sql 1.此sql用于查询表的有效字段信息table_schema当前的数据库名 select idqueryColumnsByTableName resultTypecom.hle.monitor.entity.vo.ColumnsDtoSELECTcolumn_name,data_typeFROMinformation_schema.COLUMNSWHEREtable_name #{tableName}AND table_schema supervision_dataORDER BY ordinal_position/select2.再用sql查询表的所有数据(注意此处表名需要要用$而不是#号) select idfindBackupAll resultTypejava.util.Mapselect * from ${tableName}/select 此处我省略了相应的service和mapper文件内容直接展示最重要的controller代码 import com.hle.monitor.entity.Results; import com.hle.monitor.entity.vo.ColumnsDto; import com.hle.monitor.service.UserService; import com.hle.monitor.util.DateUtils; import com.hle.monitor.util.MinIoUtil; import com.hle.monitor.util.ParameterUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.http.entity.ContentType; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Scope; import org.springframework.mock.web.MockMultipartFile; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile;import javax.annotation.Resource; import java.io.*; import java.lang.reflect.Field; import java.util.Arrays; import java.util.Date; import java.util.List; import java.util.Map;/*** author*/ CrossOrigin(origins *) RestController() RequestMapping(/backup) Api(tags 备份相关接口类) Scope(prototype) public class BackupController {Autowiredprivate UserService userService;ResourceMinIoUtil minIoUtil;//本地文件夹路径private static String backupFilePath ./sql/;ApiOperation(value 根据表名备份信息)GetMapping(/{tableName})public Results backupTable(PathVariable(tableName) String tableName) {//表有效字段信息ListColumnsDto columnsDtoList userService.queryColumnsByTableName(tableName);if(columnsDtoList.isEmpty()) return new Results(500, 该表无有效字段信息);//文件名--先在本地创建写入后再进行删除String fileName System.currentTimeMillis() - tableName .sql;try {//获取所有备份数据ListMapString, Object records userService.findBackupAll(tableName);String path backupFilePath fileName;//不存在文件夹则创建File directory new File(backupFilePath);directory.mkdirs();BufferedWriter writer new BufferedWriter(new FileWriter(path));for (Map record : records) {String insertStatement generateInsertStatement(tableName, record, columnsDtoList) ;;writer.write(insertStatement);writer.newLine();}writer.close();File file new File(path);InputStream inputStream new FileInputStream(file);MultipartFile multipartFile new MockMultipartFile(ContentType.APPLICATION_OCTET_STREAM.toString(), inputStream);minIoUtil.upload(multipartFile, ParameterUtil.bucketNameParam, fileName);//上传后 删除本地文件file.delete();System.out.println(Backup created successfully!);} catch (IOException e) {e.printStackTrace();return new Results(500, 操作失败);}return new Results(200, 操作成功, fileName);}//此方法需要以数据库取出来的字段信息为准--转换成sql的方法private String generateInsertStatement(String tableName, MapString, Object record, ListColumnsDto columnsDtoList) {StringBuilder builder new StringBuilder();builder.append(INSERT INTO ).append(tableName).append( ();//拼接列名columnsDtoList.forEach(columns - {builder.append(columns.getColumn_name()).append(, );});builder.setLength(builder.length() - 2);builder.append() VALUES ();//拼接值columnsDtoList.forEach(columns - {Object value record.get(columns.getColumn_name());if(value instanceof Date){Date date (Date) value;builder.append().append(DateUtils.parseDateToStr(date)).append(, );}else if(value instanceof String){builder.append().append(value).append(, );}else{builder.append(value).append(, );}});builder.setLength(builder.length() - 2);builder.append());return builder.toString();}//此方法用于直接取Object的字段信息做sql拼接--转换成sql的方法--已验证过private String generateInsertStatement(String tableName, Object record) {StringBuilder builder new StringBuilder();builder.append(INSERT INTO ).append(tableName).append( ();Arrays.stream(record.getClass().getDeclaredFields()).map(Field::getName).forEach(fieldName - builder.append(convertCamelCaseToSnakeCase(fieldName)).append(, ));builder.setLength(builder.length() - 2);builder.append() VALUES ();Arrays.stream(record.getClass().getDeclaredFields()).map(field - {field.setAccessible(true);try {return field.get(record);} catch (IllegalAccessException e) {e.printStackTrace();return null;}}).forEach(value - {if(value instanceof Date){//时间格式 转换为-YYYY_MM_DD_HH_MM_SSDate date (Date) value;builder.append().append(DateUtils.parseDateToStr(date)).append(, );}else if(value instanceof String){builder.append().append(value).append(, );}else{//int/double类型 不需要单引号builder.append(value).append(, );}});builder.setLength(builder.length() - 2);builder.append());return builder.toString();}//驼峰命令转换 userName-转换为-user_namepublic static String convertCamelCaseToSnakeCase(String input) {return input.replaceAll(([a-z])([A-Z]), $1_$2).toLowerCase();}}在controller中提供了两种方法可以参考一下然后直接调用接口就行 因为项目需要我是写入文件后再上传至minio文件服务器所以我要查看还需要去minio服务器查看下载或者调用现有的下载接口下载 这样就完成了根据sql文件数据备份
http://www.pierceye.com/news/99062/

相关文章:

  • 网站标题格式建设网站南昌
  • wordpress作企业网站好吗沈阳短视频制作公司
  • 表格网站怎么做的作文网站大全
  • 比特币网站建设专业网站建设企业网站制作
  • 故宫博物院官网网站咋做的山东省济宁市最新消息
  • 天河营销型网站建设html网页设计代码作业正能量
  • 国外网站设计欣赏智能获客系统
  • 济南网站建设599网站建设完工后在什么科目核算
  • 学校网站的作用app营销推广方式
  • 怎么做网站互换链接重庆工程建设信息网官网查询
  • 刚开始做网站要传数据库吗赛迪建设网站
  • 网站网络推广教程手机html网站开发视频
  • 网站弹出广告代码口碑好的龙岗网站建设
  • 东莞网站建设-搜盟网电商的运营推广
  • 美发网站 源代码网站建设的博客
  • 做电影视频网站赚钱嘛安溪人做的网站
  • 网站建设基础代码赣州专门网公司
  • 购物网站答辩ppt怎么做网站开发环境
  • 做网站的费用计入销售费用吗做装修效果图的网站
  • 企业网站制作深圳免费域名映射
  • 安徽建设厅网站施网站的静态页面谁做
  • 网站内页seo桂林山水甲天下是哪个景点
  • 外贸网站免费建站小榄网站建设公司
  • 做旅游网站赚钱吗wordpress模板调用自定义插件
  • 南宁手机网站建设工艺品做网站
  • 可以下载电影的网站怎么做适合程序员的wordpress主题
  • 哪些网站微信支付平台建设网站软件
  • 做系统网站赚钱做爰网站有哪些
  • 新密做网站公司网站建设工作部署会
  • 上海网站推广方法怎么做网页 网站制作