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

网站建设培训方案google推广及广告优缺点

网站建设培训方案,google推广及广告优缺点,郑州网站推广,创恒建设有限公司网站1. 介绍 在应用开发中,当数据不大时使用 for循环一条一条的插入,这个方式比较简单直观灵活,但是这个对于大的数据集,使用for循环逐条插入数据可能会导致性能问题。在网络延迟高或数据库负载大的情况下。使用for循环进行数据插入时…

1. 介绍

  1. 在应用开发中,当数据不大时使用 for循环一条一条的插入,这个方式比较简单直观灵活,但是这个对于大的数据集,使用for循环逐条插入数据可能会导致性能问题。
  2. 在网络延迟高或数据库负载大的情况下。使用for循环进行数据插入时,需要注意事务管理,确保数据的一致性和完整性。如果不适当地管理事务,可能会导致数据不一致或丢失。
  3. 每次循环迭代都需要建立和关闭数据库连接,这可能会导致额外的数据库连接开销,影响性能。

针对有大数据量批量插入语句的场景,此时有两种方案 1. 多条insert同时提交 ,2. insert…vaues (),()的语句形式批量提交。

在DM中推荐使用PreparedStatement预编译多条insert语句 然后executeBatch的操作也就是第一种方法

2. 使用PreparedStatement预编译

使用预处理的方式进行批量插入是一种常见的优化方法,它可以显著提高插入操作的性能。

优点:

  • 性能提升: 预处理可以减少每次插入操作中的数据库通信次数,从而降低了网络通信的开销,提高了插入操作的效率和性能。
  • 减少数据库负载: 将多条数据组合成批量插入的方式可以减少数据库服务器的负载,降低了数据库系统的压力,有助于提高整个系统的性能。
  • 减少连接开销: 预处理可以减少每次循环迭代中建立和关闭数据库连接的开销,从而节省了系统资源,提高了连接的复用率。
  • 事务管理:可以将多个插入操作放在一个事务中,以确保数据的一致性和完整性,并在发生错误时进行回滚,从而保证数据的安全性。

缺点:

  • 内存消耗: 将多条数据组合成批量插入的方式可能会增加内存消耗,特别是在处理大量数据时。因此,需要注意内存的使用情况,以避免内存溢出或性能下降。

所以由此可见预编译方式性能较好,如果想避免内存问题的话,其实使用分批插入也可以解决这个问题。

3. spring中标准的单条提交写法(不推荐)

    @Overridepublic void batchInsertGOOD(BRAND bRAND, SHELL sHELL) throws IOException {String[] good_string = null;Integer CATEGORY_ID = 1;for (int i = 0; i < 100000; i++) {GOOD good = new GOOD();good.setBRAND_ID(bRAND.getID());good.setBRAND_UUID(bRAND.getBRAND_ID());good.setSELLER_ID(sHELL.getID());good.setSELLER_UUID(sHELL.getSHELL_ID());good.setGOOD_ID(CustomUtil.getUUID());good.setNAME(i+good_string[2]);good.setPRICE(new BigDecimal(good_string[1]));good.setGOOD_DESC("这时商品介绍---"+i+"----"+good_string[2]);good.setIS_DELETE(0);gOODMapper.insert(good);}}

使用com.baomidou.mybatisplus.core.mapper.BaseMapper

4. insert…vaues (),()的语句形式批量提交 (不推荐)

insert…vaues (),() 的语句形式批量提交。使用mysql数据库的话通常使用的这种写法。

这种写法会导致sql语句会非常大,不仅容易超出的sql长度限制,也会容易造成oom。

   @Overridepublic void batchInsertGOOD_CUSTOM_T(BRAND bRAND, SHELL sHELL) throws IOException {List<GOOD> goodLists = new ArrayList<>();String[] good_string = null;Integer CATEGORY_ID = 1;for (int i = 0; i < 100000; i++) {GOOD good = new GOOD();good.setBRAND_ID(bRAND.getID());good.setBRAND_UUID(bRAND.getBRAND_ID());good.setSELLER_ID(sHELL.getID());good.setSELLER_UUID(sHELL.getSHELL_ID());good_string = CustomUtil.readTargetFileNum(RandomUtil.randomInt(1, 15),StrUtil.trim(bRAND.getBRAND_JC()));//产品类型good.setCATEGORY_ID(RandomUtil.randomInt(1, 10));good.setGOOD_ID(CustomUtil.getUUID());good.setNAME(i+good_string[2]);good.setPRICE(new BigDecimal(good_string[1]));good.setGOOD_DESC("这时商品介绍---"+i+"----"+good_string[2]);good.setIS_DELETE(RandomUtil.randomInt(0, 1));goodLists.add(good);//每5000次 提交一次数据if(i%5000==0&&i!=0){gOODMapper.batchInsertList(goodLists);goodLists.clear();}}if(goodLists.size()!=0){gOODMapper.batchInsertList(goodLists);}}

在Myabtis中xml文件的写法,使用foreach标签循环变量结果集

<insert id="batchInsertList" parameterType="java.util.List">insert into "DM_GOODS"( "GOOD_ID", "NAME", "PRICE", "GOOD_DESC", "BRAND_ID", "BRAND_UUID", "CATEGORY_ID", "SELLER_ID", "SELLER_UUID", "IS_DELETE")VALUES<foreach collection="goodsList" item="good" separator=",">(#{good.GOOD_ID},#{good.NAME},#{good.PRICE},#{good.GOOD_DESC},#{good.BRAND_ID},#{good.BRAND_UUID},#{good.CATEGORY_ID},#{good.SELLER_ID},#{good.SELLER_UUID},#{good.IS_DELETE})</foreach></insert>

在DM中如果拼接的?参数过多时,会报变量空间溢出这个问题,此时查看日志会发现有多条数据就要拼接多少次。

5. mybatis自带的savebatch方法(推荐)


@Service
public class GOODServiceImpl extends ServiceImpl<GOODMapper, GOOD> implements GOODService {@Autowiredprivate GOODService gOODService;@Overridepublic void batchInsertGood_Mys_SaveBatch(BRAND bRAND, SHELL sHELL) throws IOException {List<GOOD> goodLists = new ArrayList<>();String[] good_string = null;Integer CATEGORY_ID = 1;for (int i = 0; i < 100000; i++) {GOOD good = new GOOD();good.setBRAND_ID(bRAND.getID());good.setBRAND_UUID(bRAND.getBRAND_ID());good.setSELLER_ID(sHELL.getID());good.setSELLER_UUID(sHELL.getSHELL_ID());good_string = CustomUtil.readTargetFileNum(RandomUtil.randomInt(1, 15),StrUtil.trim(bRAND.getBRAND_JC()));//产品类型good.setCATEGORY_ID(RandomUtil.randomInt(1, 10));good.setGOOD_ID(CustomUtil.getUUID());good.setNAME(i+good_string[2]);good.setPRICE(new BigDecimal(good_string[1]));good.setGOOD_DESC("这时商品介绍---"+i+"----"+good_string[2]);good.setIS_DELETE(RandomUtil.randomInt(0, 1));goodLists.add(good);//每5000次 提交一次数据if(i%1000==0&&i!=0){//ServiceImpl的saveBatch方法,默认batchsize是1000gOODService.saveBatch(goodLists);goodLists.clear();}}if(goodLists.size()!=0){gOODService.saveBatch(goodLists);}}}

通过查看sqllog日志,发现saveBatch接口使用PreparedStatement预编译多条insert语句 然后executeBatch提交。



6. savebatch源码分析

eg:在DM中没有rewriteBatchedStatements 参数,因为跟mysql的驱动内部的executeBatch()函数实现不同。

6.1 com.baomidou.mybatisplus.extension.toolkit.SqlHelper#executeBatch

executeBatch函数用于执行批量操作。主要功能如下:

  1. 检查批次大小是否合法。
  2. 如果数据集合不为空,则调用另一个 executeBatch 方法,逐个处理集合中的元素,并在达到批次大小或处理完所有元素时刷新语句。
  3. sqlSession.flushStatements将一个个单条插入的insert语句分批次进行提交,用的是同一个sqlSession。
    public static <E> boolean executeBatch(Class<?> entityClass, Log log, Collection<E> list, int batchSize, BiConsumer<SqlSession, E> consumer) {Assert.isFalse(batchSize < 1, "batchSize must not be less than one");return !CollectionUtils.isEmpty(list) && executeBatch(entityClass, log, sqlSession -> {int size = list.size();int i = 1;for (E element : list) {consumer.accept(sqlSession, element);if ((i % batchSize == 0) || i == size) {sqlSession.flushStatements();}i++;}});}

6.2 org.apache.ibatis.executor.BatchExecutor#doFlushStatements

doFlushStatements函数处理批量执行 SQL 语句并返回结果。主要功能如下:

  1. 如果是回滚操作,直接返回空列表。
  2. 遍历 statementList,对每个 Statement 执行批量更新,并处理生成的主键。
  3. 捕获批量更新异常,构建错误信息并抛出异常。
  4. 最后清理资源和状态。

    此处的stmt.executeBatch()函数,直接调的是DM的do_executeLargeBatch函数
http://www.dtcms.com/wzjs/373901.html

相关文章:

  • 岳阳汨罗网站建设网站优化系统
  • 广州快速建站哪家服务专业网页自助建站
  • 河南造价信息网官网哪个网站学seo是免费的
  • 兰州网站设计厂家上海公布最新情况
  • 体育用品电子商务网站建设方案互联网营销的方式有哪些
  • 网站报名怎么做企业网站的推广阶段
  • 沙漠风网站建设怎么样公众号软文素材
  • 开发app的注意事项做网站优化的公司
  • 用凡科做的手机网站版如何做推广宣传
  • 以前自己做的网站怎么样删除运营培训班
  • 做网站具体流程网络运营推广
  • 企业做英文网站自动seo网站源码
  • 网站按钮确定后图片怎么做进入百度官网
  • 网站设计可以用性原则不受国内限制的搜索引擎
  • 做外卖有哪些网站有哪些北京百度公司地址在哪里
  • 青苹果网站建设网址模板建站
  • 黄网站搭建注意什么意思数据分析师35岁以后怎么办
  • 公司网站建设的心得seo服务靠谱吗
  • 如何在自己网站上做支付宝吗上海不限关键词优化
  • 禹城网站制作怎么在百度上免费做广告
  • 做网站需要固定ip好口碑关键词优化
  • 做网站有哪几种语言佛山百度推广公司
  • 行业前10的网站建设公司厦门seo屈兴东
  • web网站开发不必掌握哪些计数百度推广怎么操作
  • 免费建网站平台哪个好网络营销专业学什么
  • 饮料网站建设价格外链seo服务
  • 前程无忧怎么做网站南京seo整站优化技术
  • 建设中心小学网站cms建站
  • 深圳做网站商线上职业技能培训平台
  • 淘宝客如何建立自己的网站百度推广非企代理