• 2024-12-11大数据-247 离线数仓 - 电商分析 拉链表的分析与构建与回滚
    点一下关注吧!!!非常感谢!!持续更新!!!Java篇开始了!目前开始更新MyBatis,一起深入浅出!目前已经更新到了:Hadoop(已更完)HDFS(已更完)MapReduce(已更完)Hive(已更完)Flume(已更完)Sqoop(已更完)Zookeeper(已更完)HBase(已更完)Redis(已更完)Kafka(已更完)Spark(已更完)Flink(已更完)ClickHouse(已更完)Kudu(
  • 2024-12-05gbase&oracle行转列函数
    转:https://blog.csdn.net/manonggeerdan/article/details/126299268?share_token=27704f7a-a864-49b2-b294-4586956169bd一、group_concat(适用于mysql、gbase)1、功能:将groupby产生的同一个分组中的值连接起来,返回一个字符串结果。2、语法:group_concat([distinct]要连接的字
  • 2024-11-28批量操作工具
    批量操作工具背景比如有时候csv或者excel导入了一批数据,然后想着每次1000条操作一次数据库/***@description:*@author:lyc*@date:2024/4/1215:13**/publicclassBatchHandleUtils{/***一次性读取文档批量处理数据入库*@paramb
  • 2024-11-23Spring Events在大型项目中的最佳实践
    在大型项目中,SpringEvents提供了一种有效的方式来解耦不同的模块,使得系统更加灵活和可扩展。SpringEvents基于发布/订阅模式,允许应用的不同部分之间进行通信,而无需直接调用对方的代码。这种方式特别适合于处理那些不需要即时反馈的业务场景。实际业务场景假设我们正在开发
  • 2024-12-11营销怎么落地
    为什么营销不落地?营销要解决的问题是什么?营销该怎么干?营销不接地气,是90%企业的痛:有好产品,销量不高。营销活动八仙过海,用户却感知不到产品的价值,业绩不好。1、为什么营销不落地?举例某企业营销部门每天干得热火朝天,拍摄创意广告,去做电梯广告、社区广告、公交广告,每个人都很
  • 2024-12-05查询某字段有特殊字符(PATINDEX函数)
    查询某字段有特殊字符(PATINDEX函数)创建时间:2023年11月09日概要在工作中遇到用户的usercode字段出现特殊字符。例如点,空格这些字符在开发中没有很好去做校验,需要在后台数据库中将这些有问题进行修改。技术server的select查询语句server的update更新语句查询语法SELECT*
  • 2024-11-25ALINX 为什么要推出 IP Core 产品线?
      近年来,5G网络的全面部署与人工智能(AI)的迅速普及扩大了FPGA的应用市场。 一方面,传统CPU处理架构在面对实时数据流量和存储操作时容易产生瓶颈,FPGA恰好凭借其高性能、低功耗的特点满足了爆炸式增长的高效数据处理和存储需求。 另一方面,FPGA的可编程性又能很好地
  • 2024-09-30大数据-156 Apache Druid 案例实战 Scala Kafka 订单统计
    点一下关注吧!!!非常感谢!!持续更新!!!目前已经更新到了:Hadoop(已更完)HDFS(已更完)MapReduce(已更完)Hive(已更完)Flume(已更完)Sqoop(已更完)Zookeeper(已更完)HBase(已更完)Redis(已更完)Kafka(已更完)Spark(已更完)Flink(已更完)ClickHouse(已更完)Kudu(已更完)Druid(正在更新…)章节内容上节我们完成了如
  • 2024-09-12不使用Redis分布式锁,如何避免用户重复点击提交?
    前端,在用户点击后,对按钮做置灰操作。但有些情况,用户会绕过置灰,实现重复点击。后端,对客户端携带的token,验证是否使用过;验证逻辑,存储在数据库中,验证逻辑使用悲观锁或者乐观锁实现。前端按钮置灰前端按钮置灰:在用户点击按钮后,将按钮禁用一段时间或直到请求响应。优点:简
  • 2024-09-07我司使用了两年的高效日志打印工具,非常牛逼!
    为了更方便地排查问题,电商交易系统的日志中需要记录用户id和订单id等字段。然而,每次打印日志都需要手动设置用户id,这一过程非常繁琐,需要想个办法优化下。log.warn("user:{},orderId:{}订单提单成功",userId,orderId);log.warn("user:{},orderId:{}订单支付成功",userId,orde
  • 2024-08-29利用 Redisson 实现延迟消息队列:一种高效订单取消方案
    文章目录一、发送延迟消息:定时触发订单取消二、监听延迟队列:自动处理过期订单三、取消订单的实现逻辑四、总结在电商平台中,订单生成后如果长时间未被处理,我们通常需要自动取消这些订单。这种需求不仅能够提升用户体验,还能有效管理库存和资源分配。而如何实现这一需
  • 2024-08-20鸿蒙Next-支付宝SDK接入教程
    App适配鸿蒙Next,开始做支付功能了,目前来说只有支付宝支持鸿蒙Next,微信还没上架,但是支付宝官方的文档跟Demo都很老,下载官方的Demo用最新版的DevEco-Studio导入都不成功。后面在OpenHarmony三方库中心仓找到了最新的代码:https://ohpm.openharmony.cn/#/cn/detail/@cashier_alipay
  • 2024-08-16订单支付倒计时redis实现
    订单支付倒计时redis实现@GetMapping("/addOrder")publicStringaddOrder(){//创建订单...数据库操作//订单ID存到Redis,存30分钟redisTemplate.opsForValue().set("orderId1234","添加的订单",30,TimeUnit.MINUTES);retu
  • 2024-08-13【easyexcel自定义模版导出,字体样式设置】
    文章目录系列文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言学以致用,开箱即用一、maven引包<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.7</version></dependency>
  • 2024-08-11Redis8-秒杀优化
    秒杀思路之前: Redis优化: 基于Redis完成秒杀资格判断需求:新增秒杀优惠券的同时,将优惠券信息保存到Redis中基于Lua脚本,判断秒杀库存、一人一单,决定用户是否抢购成功如果抢购成功,将优惠券id和用户id封装后存入阻塞队列开启线程任务,不断从阻塞队列中获取信息,实现异
  • 2024-07-20mq发送消息一般步骤
    添加依赖<!--消息发送--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>配置spring:rabbitmq:host:192.168.150.101#你的虚拟
  • 2024-07-14Java进阶之路66问 | 什么是幂等性?如何保证接口的冥等性?
    API设计中的幂等性什么是幂等性幂等性是指无论一个操作执行多少次,最终的结果都是一样的。也就是说,重复执行同一个操作不会改变系统的状态或产生不同的结果。想象你在一栋大楼里等电梯。你按下电梯按钮的5楼按钮键,电梯开始向5楼的位置移动。后面即使你再按几次5楼按钮键,
  • 2024-06-17uni app 安卓微信支付唤起实现
    唤起微信支付核心代码asyncweixinPayApp(){ constself=this; letpostApi=''; if(this.checkWexin){ postApi='getOpenWeixinSignOrderInfo'; }elseif(this.checkAliPay){ postApi='getAlipaySignOrderInfoForApp'
  • 2024-06-17【SQL边干边学系列】09高级问题-5
    文章目录前言回顾高级问题52.有供应商或客户的国家53.有供应商或客户的国家-版本254.有供应商或客户的国家-版本355.每个国家的第一个订单56.在5天的期限内有多个订单的客户57.在5天期限内有多个订单的客户-版本2答案52.有供应商或客户的国家53.有供应商或客户的
  • 2024-06-06sql 条件用空值进行比对的结果
    selectSUM(e.Qty)asInputQtyfromUT_InputInfoasainnerjoinT_ProcessDefasbona.ProcessID=b.ProcessIDinnerjoinUT_PrdTaskasdona.OrderID=d.OrderIDinnerjoindbo.UT_LabelInfoRecaseona.LabelPrtRecID=e.PrtRecIDinnerjoinUT_PrdTaskash