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

江浙沪做网站的公司惠阳东莞网站建设

江浙沪做网站的公司,惠阳东莞网站建设,个人网址是什么,网站备案怎么备案用jackson转json有时您需要将大量数据导出到JSON到文件中。 也许是“将所有数据导出到JSON”#xff0c;或者是GDPR“可移植性的权利”#xff0c;您实际上需要这样做。 与任何大型数据集一样#xff0c;您不能只将其全部容纳在内存中并将其写入文件。 这需要一段时间… 用jackson转json 有时您需要将大量数据导出到JSON到文件中。 也许是“将所有数据导出到JSON”或者是GDPR“可移植性的权利”您实际上需要这样做。 与任何大型数据集一样您不能只将其全部容纳在内存中并将其写入文件。 这需要一段时间它会从数据库中读取大量条目并且您需要注意不要使此类导出使整个系统超载或耗尽内存。 幸运的是借助Jackson的SequenceWriter和可选的管道流这样做非常简单。 看起来像这样 private ObjectMapper jsonMapper new ObjectMapper();private ExecutorService executorService Executors.newFixedThreadPool(5);Asyncpublic ListenableFutureBoolean export(UUID customerId) {try (PipedInputStream in new PipedInputStream();PipedOutputStream pipedOut new PipedOutputStream(in);GZIPOutputStream out new GZIPOutputStream(pipedOut)) {Stopwatch stopwatch Stopwatch.createStarted();ObjectWriter writer jsonMapper.writer().withDefaultPrettyPrinter();try(SequenceWriter sequenceWriter writer.writeValues(out)) {sequenceWriter.init(true);Future? storageFuture executorService.submit(() -storageProvider.storeFile(getFilePath(customerId), in));int batchCounter 0;while (true) {ListRecord batch readDatabaseBatch(batchCounter);for (Record record : batch) {sequenceWriter.write(entry);}}// wait for storing to completestorageFuture.get();} logger.info(Exporting took {} seconds, stopwatch.stop().elapsed(TimeUnit.SECONDS));return AsyncResult.forValue(true);} catch (Exception ex) {logger.error(Failed to export data, ex);return AsyncResult.forValue(false);}} 该代码可以做一些事情 使用SequenceWriter连续写入记录。 它使用OutputStream初始化所有内容均写入其中。 这可以是简单的FileOutputStream也可以是如下所述的管道流。 注意这里的命名有点误导– writeValues(out)听起来就像您在指示编写者现在写东西 而是将其配置为以后使用特定的流。 SequenceWriter用true初始化表示“包装在数组中”。 您正在编写许多相同的记录因此它们应在最终JSON中表示一个数组。 使用PipedOutputStream和PipedInputStream将SequenceWriter链接到InputStream 然后将InputStream传递到存储服务。 如果我们明确地使用文件则不需要这样做-只需传递FileOutputStream就可以。 但是您可能想要以不同的方式存储文件例如在Amazon S3中并且putObject调用需要一个InputStream从该InputStream可以读取数据并将其存储在S3中。 因此实际上您正在写入一个OutputStream而该OutputStream会直接写入InputStream当被输入以读取该输入流时会将所有内容写入另一个OutputStream 存储文件是在单独的线程中调用的因此写入文件不会阻塞当前线程当前线程的目的是从数据库中读取数据。 同样如果使用简单的FileOutputStream则不需要这样做。 整个方法被标记为Asyncspring因此它不会阻止执行-它被调用并在准备就绪时完成使用内部Spring executor服务和有限的线程池 这里未显示数据库批处理读取代码因为它随数据库的不同而不同。 关键是您应该分批提取数据而不是SELECT * FROMX。 OutputStream包装在GZIPOutputStream中因为带有重复元素的JSON之类的文本文件可从压缩中显着受益 主要工作是由Jackson的SequenceWriter完成的显而易见的要点是–不要假设您的数据适合内存。 它几乎永远不会做所以批量处理和增量写入都是如此。 翻译自: https://www.javacodegeeks.com/2018/08/writing-big-json-files-jackson.html用jackson转json
http://www.zqtcl.cn/news/337221/

相关文章:

  • 商丘做网站的价格专业网站制作哪家强
  • 瑞安微信网站软件公司网站设计与制作
  • 片头网站网站建设服装在线商城实训报告
  • wordpress做企业网站怎样做网页推广
  • 网站建设售后服务安全维护企业网站开发 外文文献
  • 网站设计英文翻译系统开发的五个阶段
  • 成华区门户网站拍卖网站开发多少钱
  • html设计网站wordpress 评论增加字段
  • 搭建正规网站小程序开发难不难
  • 做静态网站用什么软件自己编写代码建设微网站
  • 备案网站ipoa系统主要干什么的
  • 杭州专业网站建设在哪里wordpress主题重置
  • 仿wordpress站赣州专业网站推广
  • 网站开发需要多长时间python链接wordpress
  • 网上交易网邯郸网站seo
  • wordpress图片后加载外链seo服务
  • 婚庆公司网站建设腾讯广告建站工具
  • 焦作建设厅网站wordpress调用视频播放器
  • 网站版面做好江苏省建设工程设计施工图审核中心网站
  • 智能网站平台wordpress同步头条
  • 做采集的网站有流量吗广州建设学校
  • 建设部网站公告外贸网站建设定制
  • 如何搭建 seo网站上海市住房与城乡建设部网站
  • 百度搜不到自己的网站python云服务器网站开发实例
  • 给企业做网站的业务员优书网没了
  • 江门网站建设方案外包洛阳网站设计哪家专业
  • 电暖怎么做网站办公室平面设计图
  • 全屏网站 功能丽水市企业网站建设 微信营销 影视拍摄
  • 天天爱天天做视频网站网站推送
  • 制作企业网站与app有什么不同化工企业网站建设