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

网站建设SEO优化哪家好网站自动收录

网站建设SEO优化哪家好,网站自动收录,政府网站建设自查,南宁最高端网站建设文章目录 1.分页插件2.自定义分页3.乐观锁3.1 场景3.2 乐观锁与悲观锁3.3 模拟修改冲突3.4 乐观锁解决问题 1.分页插件 MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能 添加配置类MyBatisPlusConfig Configuration MapperScan("com.atguigu.mybatis…

文章目录

    • 1.分页插件
    • 2.自定义分页
    • 3.乐观锁
      • 3.1 场景
      • 3.2 乐观锁与悲观锁
      • 3.3 模拟修改冲突
      • 3.4 乐观锁解决问题

1.分页插件

MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能

  • 添加配置类MyBatisPlusConfig

    @Configuration
    @MapperScan("com.atguigu.mybatisplus.mapper")
    public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();//添加分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
    }
    
  • 编写测试方法

    @Test
    public void testPage(){//new Page()中的两个参数分别是当前页码,每页显示数量Page<User> page = userMapper.selectPage(new Page<>(1, 2), null);List<User> users = page.getRecords();users.forEach(System.out::println);
    }
    

2.自定义分页

上面调用的是MyBatis-Plus提供的带有分页的方法,那么我们自己定义的方法如何实现分页呢?

  • UserMapper接口中定义一个方法

    /*** 根据年龄查询用户列表,分页显示 * @param page 分页对象,xml中可以从里面进行取值,传递参数 Page 即自动分页,必须放在第一位 * @param age 年龄 * @return */
    Page<User> selectPageVo(@Param("page") Page<User> page,@Param("age") Integer age);
    
  • UserMapper.xml中编写SQL实现该方法

    <select id="selectPageVo" resultType="User">select id,username as name,age,email from t_user where age > #{age}
    </select>
    
  • 编写测试方法

    @Test
    public void testPageVo(){Page<User> page = userMapper.selectPageVo(new Page<User>(1,2), 20);List<User> users = page.getRecords();users.forEach(System.out::println);
    }
    

3.乐观锁

作用:当要更新一条记录的时候,希望这条记录没有被别人更新

乐观锁的实现方式:

  • 取出记录时,获取当前 version
  • 更新时,带上这个 version
  • 执行更新时, set version = newVersion where version = oldVersion
  • 如果 version 不对,就更新失败

3.1 场景


  • 一件商品,成本价是80元,售价是100元。老板先是通知小李,说你去把商品价格增加50元。小李正在玩游戏,耽搁了一个小时。正好一个小时后,老板觉得商品价格增加到150元,价格太高,可能会影响销量。又通知小王,你把商品价格降低30元。
  • 此时,小李和小王同时操作商品后台系统。小李操作的时候,系统先取出商品价格100元;小王也在操作,取出的商品价格也是100元。小李将价格加了50元,并将100+50=150元存入了数据库;小王将商品减了30元,并将100-30=70元存入了数据库。是的,如果没有锁,小李的操作就完全被小王的覆盖了。
  • 现在商品价格是70元,比成本价低10元。几分钟后,这个商品很快出售了1千多件商品,老板亏1万多。

3.2 乐观锁与悲观锁


  • 上面的故事,如果是乐观锁,小王保存价格前,会检查下价格是否被人修改过了。如果被修改过了,则重新取出的被修改后的价格,150元,这样他会将120元存入数据库。
  • 如果是悲观锁,小李取出数据后,小王只能等小李操作完之后,才能对价格进行操作,也会保证最终的价格是120元。

3.3 模拟修改冲突


  • 数据库中增加商品表

    CREATE TABLE t_product ( id BIGINT(20) NOT NULL COMMENT '主键ID', NAME VARCHAR(30) NULL DEFAULT NULL COMMENT '商品名称', price INT(11) DEFAULT 0 COMMENT '价格', VERSION INT(11) DEFAULT 0 COMMENT '乐观锁版本号', PRIMARY KEY (id) 
    );
    
  • 添加一条数据

    INSERT INTO t_product (id, NAME, price) VALUES (1, '外星人笔记本', 100);
    
  • 添加一个实体类Product

    @Data
    public class Product {private Long id;private String name;private Integer price;private Integer version;
    }
    
  • 添加一个Mapper接口ProductMapper

    public interface ProductMapper extends BaseMapper<Product> {}
    
  • 测试方法

    @Test
    public void testProduct01(){//1.小李获取商品价格Product productLi = productMapper.selectById(1);System.out.println("小李获取的商品价格为:" + productLi.getPrice());//2.小王获取商品价格Product productWang = productMapper.selectById(1);System.out.println("小李获取的商品价格为:" + productWang.getPrice());//3.小李修改商品价格+50productLi.setPrice(productLi.getPrice()+50);productMapper.updateById(productLi);//4.小王修改商品价格-30productWang.setPrice(productWang.getPrice()-30);productMapper.updateById(productWang);//5.老板查询商品价格Product productBoss = productMapper.selectById(1);System.out.println("老板获取的商品价格为:" + productBoss.getPrice());
    }
    
  • 执行结果

    image-20220521225803162

3.4 乐观锁解决问题


  • 实体类version字段添加注解@Version

    @Data
    public class Product {private Long id;private String name;private Integer price;@Versionprivate Integer version;
    }
    
  • 添加乐观锁插件配置

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();//添加分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));//添加乐观锁插件interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return interceptor;
    }
    
  • 再次执行测试方法

    小李查询商品信息:

    ​ SELECT id,name,price,version FROM t_product WHERE id=?

    小王查询商品信息:

    ​ SELECT id,name,price,version FROM t_product WHERE id=?

    小李修改商品价格,自动将version+1

    ​ UPDATE t_product SET name=?, price=?, version=? WHERE id=? AND version=?

    ​ Parameters: 外星人笔记本(String), 150(Integer), 1(Integer), 1(Long), 0(Integer)

    小王修改商品价格,此时version已更新,条件不成立,修改失败

    ​ UPDATE t_product SET name=?, price=?, version=? WHERE id=? AND version=?

    ​ Parameters: 外星人笔记本(String), 70(Integer), 1(Integer), 1(Long), 0(Integer)

    最终,小王修改失败,查询价格:150

    ​ SELECT id,name,price,version FROM t_product WHERE id=?

  • 优化执行流程

    @Test
    public void testProduct01(){//1.小李获取商品价格Product productLi = productMapper.selectById(1);System.out.println("小李获取的商品价格为:" + productLi.getPrice());//2.小王获取商品价格Product productWang = productMapper.selectById(1);System.out.println("小李获取的商品价格为:" + productWang.getPrice());//3.小李修改商品价格+50productLi.setPrice(productLi.getPrice()+50);productMapper.updateById(productLi);//4.小王修改商品价格-30productWang.setPrice(productWang.getPrice()-30);int result = productMapper.updateById(productWang);if(result == 0){//操作失败,重试Product productNew = productMapper.selectById(1);productNew.setPrice(productNew.getPrice()-30);productMapper.updateById(productNew);}//5.老板查询商品价格Product productBoss = productMapper.selectById(1);System.out.println("老板获取的商品价格为:" + productBoss.getPrice());
    }
    

    image-20220521230448577

http://www.dtcms.com/wzjs/330275.html

相关文章:

  • wordpress页面的templateseo关键词挖掘
  • 焦作网站建设策划杭州网站设计
  • 提升网站关键词排名创建免费网站
  • 交友网站免费建设新浪舆情通
  • 缝纫网站做洗衣机罩公司如何做网络推广营销
  • 咸宁市住房和城乡建设委员会网站网络营销总结
  • 包头做网站百度一下就知道官方网站
  • 公司网站是否有必要销售产品高端网站建设哪个好
  • 做网站需要注册公司吗广告联盟
  • 学校网站建设方案论文淘宝关键词怎么选取
  • 网站建设报价表格小说关键词搜索器
  • 全网营销代运营公司链接优化方法
  • 南通网站制作公司seo国外推广软件
  • 潍坊做外贸网站建设关键词优化工具有哪些
  • 乐清网站优化推广百度搜索引擎服务项目
  • 写作教学网站微信朋友圈广告代理
  • 百度推广需要自己有网站吗广告加盟
  • 中国建设银行网站-个人客优化网站seo公司
  • 永康做网站公司网购网站十大排名
  • 营销网站制作哪家好中国关键词
  • doku做网站关键词优化平台有哪些
  • 建站之星平台专门代写平台
  • 成都电子商城网站开发学生没钱怎么开网店
  • 网站建设实质网络竞价
  • 专业设计网站效果seo企业推广案例
  • 哪有做网站的公司宁波seo超级外链工具
  • 企业产品推广平台疫情优化调整
  • 四平市网站建设头条今日头条新闻头条
  • 响应式网站和自适应网站的区别淘客推广
  • 网站建设必会的软件网站收录优化