OCPP1.6协议

news2024/12/29 8:54:21

目录

导言

功能简介

本地授权列表

类型

IdToken

IdTagInfo

授权状态

ChargePointErrorCode

CiString50Type

充电桩状态-ChargePointStatus

协议指令

1、授权-Authorize

1.1 说明

1.2  Authorize.req

1.3 Authorize.conf

1.4 JSON格式

1.5 代码

2、启动通知-BootNotification

2.1 说明

2.2 BootNotification.req

2.3 BootNotification.conf

2.4 JSON格式

2.5 代码

3、心跳-HeartBeat

3.1 说明

3.2 Heartbeat.req

3.3 Heartbeat.conf

3.4 JSON格式

3.5 代码

4、状态通知-StatusNotification

4.1 说明

4.2 StatusNotification.req

4.3 StatusNotification.conf

4.4 JSON格式

4.5 代码

通用方法

1、转换时间为UTC格式


导言

     这是 OCPP 1.6 版的规范。
     OCPP 是一种标准的开放式协议,用于充电站与中央系统之间的通信,可适用于任何类型的充电技术。
      OCPP 1.6 引入了适应市场的新功能:智能充电、通过 Websockets 使用 JSON 的 OCPP、更好的诊断可能性( 原因 )、更多的充电点 状态 触发信息 TriggerMessage )。OCPP 1.6 以 OCPP 1.5 为基础,增加了一些新功能和大量 文字上的改进、说明,并修正了所有已知的模糊之处。由于改进和新增功能,OCPP 1 . 6 与 OCPP 1.5 并不向后兼容 。
有关变更的完整列表,请参阅 OCPP 1.6 中的新 功能。
       一些基本概念将在本介绍性章节的以下部分进行解释。各章: 由充电桩启动的操作 由中央系统启动 的操作描述 了协议支持的操作。确切的信息及其参数将在本章中详细说明: 信息 和数据类型在 "数据类型 "一章中进行了描述 : 类型 。定义的配置密钥在 "标准配置密钥名称和参数 "一章中描述: 标准配置键名称和值
     随着 OCPP 1.6 版本的推出,OCPP 有了两种不同的版本;除了基于 SOAP 的实现外,还有可能使用更为简洁的 JSON 版本。为避免在交流中混淆实现类型,我们建议使用不同的后缀 -J 和 -S 来表示 JSON 或 SOAP。一般来说, OCPP-J 表示 JSON,OCPP-S 表示 SOAP。
为了支持不同的版本,OCPP 标准分为多个文件。基础文档(您正在阅读的文档)包含技术协议规范。 OCPP SOAP 规范》(OCPP SOAP Specification )包含实现 OCPP-S 所需的实施规范。对于 OCPP-J,必须使用 OCPP JSON 规范。
为提高中央系统与充电桩之间的互操作性,建议满足 OCPP 1.6 合规性测试 文件中的要求。

功能简介

在 OCPP 1.6 中,功能和相关信息按 配置文件 分组。根据所需功能,实施者可选择实施以下一个或多个配置文件。
客户可使用这些配置文件来确定 OCPP 1.6 产品是否具备其业务所需的功能。合规性测试将根据配置文件测试产品 是否符合 OCPP 1.6 规范。 必 须 执行核心配置文件。其他配置文件为可选配置文件。 在执行核心、固件管理、本地验证列表管理和预订配置文件时,将涵盖源自 OCPP 1.5 [OCPP1. 5 ] 的所有功能。
下表显示了所有信息在其配置文件中的分组情况

本地授权列表

类型

IdToken

包含用于授权的标识符。这是一个不区分大小写的字符串。在今后的版本中,它可能会成为 一个复杂类型,以支持 多种形式的标识符。

IdTagInfo

包含有关标识符的状态信息。它在授权、开始交易和停止交易响应中返回。
如果没有给出 expiryDate,则状态没有结束日期。

授权状态

枚举
Authorize.req 响应中的状态。

ChargePointErrorCode

StatusNotification.req 中报告的充电点状态。
中文
英文

CiString50Type

通用字符串,不区分大小写,共 50 个字符。
中文
英文

充电桩状态-ChargePointStatus

StatusNotification.req 中报告的状态。可为充电点主控制器(connectorId = 0)或特定连接器报告状态。充电点主
控制器的状态是枚举的一个子集: 可用 不可用 故障
可运行状态包括 可用 准备 充电 暂停 EVSE 暂停 EV 完成 保留 。不工作状态包括 不可用 故障
英文

协议指令

1、授权-Authorize

1.1 说明

      在电动汽车车主开始或停止充电之前,充电桩必须授权操作。充电点只能在授权后才能提供能量。停止交易时, 只有当用于停止交易的标识符与开始交易的标识符不同时,充电桩才会发送 Authorize.req 消息。
Authorize.req 应仅用于授权标识符收费。
本地授权列表 所述,充电点可在不涉及中央系统的情况下在本地授权标识符。如果用户提交的 idTag 不在本地
授权列表或授权缓存中,则充电点应向中央系统发送 Authorize.req PDU 请求授权。如果 idTag 存在于本地授权
列表或授权缓存中,则充电点可以向中央系统发送 Authorize.req PDU。
收到 Authorize.req PDU 后,中心系统应回应一个 Authorize.conf PDU。此响应 PDU 应表明中心系统是否接受
idTag。如果中心系统 接受 idTag,那么响应 PDU 可以包括 parentIdTag ,并且必须包括 表示接受或拒绝原因的 授权
状态值。
如果 Charge Point 已实施了授权缓存,那么在收到 Authorize.conf PDU 后,如果 idTag 不在 本地授权列表 中,
Charge Point 应按照 授权 缓存中所述,用响应中的 IdTagInfo 值更新缓存条目

1.2  Authorize.req

它包含充电点发送到中央系统的 Authorize.req PDU 的字段定义。

1.3 Authorize.conf

它包含中央系统为响应 Authorize.req PDU 而向充电点发送的 Authorize. conf PDU 的字段定义。

1.4 JSON格式

【SEND】♂[2,"yiBSjMizbzFWUcmz","Authorize",{"idTag":"F3F7C00B"}]


【RECV】♀[3,"yiBSjMizbzFWUcmz",{"idTagInfo":{"status":"Accepted"}}]

1.5 代码

逻辑处理

/**
*   授权
* @param data
* @param msgId
* @param msgType
* @param
* @param
* @return
*/
public ReturnData Authorize(String data,String msgId,
String msgType,String ip,String action,String body){
// 桩子 发起的充电,都要走授权
ReturnData returnData=new ReturnData();
try {
// 根据ip查询对应的设备
String equSql="select * from jk_equ where ip='"+ip+"' order by communication_time desc ";
Record equRecord=Db.findFirst(equSql);
if(null!=equRecord){
// [2,"m3MxfgtUXBR1QoyY","Authorize",{"idTag":"43AA3CA6"}]
JSONObject idTagObj=JSONObject.parseObject(data);
// 卡号 43AA3CA6
String idTag=idTagObj.getString("idTag");
IdTagInfo info=new IdTagInfo();
info.setStatus("Accepted");

// 时间推迟 60分钟
Date endDate=DateUtil.getAfterMinute(new Date(),60);
String utcStr=DateUtil.localToUTC(endDate);
info.setExpiryDate(utcStr);

List resultList=new ArrayList();
resultList.add(Integer.parseInt(msgType)+1);
resultList.add(msgId);
AuthorizeConfig authorizeConfig=new AuthorizeConfig();
authorizeConfig.setIdTagInfo(info);
resultList.add(authorizeConfig);

returnData.setResult(true);
log.info("刷卡返回信息:{}",JSON.toJSONString(resultList));
String json=new ObjectMapper().writeValueAsString(resultList);
returnData.setData(json);
}else{
log.error("收到充电点反馈,并且开启事务异常:设备不在线");
returnData.setMsg("设备不在线");
returnData.setResult(false);
}
}catch (Exception e){
log.error("收到充电点反馈,并且开启事务异常",e);
returnData.setResult(false);
}
return returnData;
}

实体类 

1、IdTagInfo

import lombok.Data;
/**
*
* 授权token回复详细信息
*/
@Data
public class IdTagInfo {
// Accepted 允许使用可充电的标识符
// Blocked 标识符已被阻止。不允许充电。
// Expired 标识符已过期。不允许充电。
// Invalid 标识符未知。不允许充电。
// ConcurrentTx 标识符已涉及到另一个事务中,并且不允许有多个事务。(仅与StartTransaction.req相关。)
private String status;
// 这其中包含idTag应该从授权缓存中删除的日期。
private String expiryDate;
//private IdToken idToken;//父级标识符。
}

2、AuthorizeConfig

import lombok.Data;
/**
* 授权配置
*/
@Data
public class AuthorizeConfig {
   private IdTagInfo idTagInfo;
}

2、启动通知-BootNotification

2.1 说明

其中包含中央系统为响应 BootNotification. req PDU 而向充电点发送的 BootNotification. conf PDU 的字段定义。
启动后,充电点应向中央系统发出请求,提供有关其配置的信息(如版本、供应商等)。中央系统应作出回应, 表明是否接受该充电点。
每次启动或重启时,充电点都应发送 BootNotification.req PDU。在物理开机/重启和成功完成 BootNotification( 中央系统返回 "接受 "或 " 等待 " 之间,充电点不得向中央系统发送任何其他请求。这包括缓存的 充电点中仍然存在的信息。
当中央系统以 " 已接受 " Accepted )状态回复 BootNotification.conf 时,充电点 将 根据回复 PDU 中的时间间隔调整心 跳间隔,建议将其内部时钟与提供的中央系统当前时间同步。如果中央系统返回的不是 " 接受 " ,则间隔字段的值表 示发送下一个启动通知请求 前的最短等待时间 。如果时间间隔值为零,则充电点自 行 选择等待时间间隔,以避免中心系统收到大量请求。除非有 TriggerMessage.req 请求,否则充电点不应提前发送 BootNotification.req
如果中央系统返回 " 拒绝 " 状态,充电点不得向中央系统发送任何 OCPP 报文,直到上述重试间隔时间结束。在此时间间隔内,中央系统可能无法再联系到充电点。例如,充电点可以关闭其通信通道或关闭其通信硬件。中央系统也可以 关闭通信通道,例如释放系统资源。 在拒绝 期间,充电点不得响应任何由中央系统发起的信息。
中央系统也可以返回一个 " 待定 " 注册状态,以表明它希望在中央系统接受该充电点之前检索或设置充电点的某些 信息。如果中央系统返回 "等待 " 状态,充电点或中央系统都不应关闭通信通道。中央系统可发送请求信息,从充电点获取信息或更改其配置。充电点应响应这些信息。除非中央系统发出 TriggerMessage.req 请求,否则充电点不得向中央系统发送请求信息。
待处理 状态下,不允许使用以下由中央系统发起的报文: RemoteStartTransaction.req
RemoteStopTransaction.req。

2.2 BootNotification.req

中文图

英文图

2.3 BootNotification.conf

中文图

英文图

2.4 JSON格式

[2,\"e3ba4698-d64b-447e-81f5-0bf0e09700eb\",\"BootNotification\",{\"chargePointVendor\":\"\",\"chargePointModel\":\"\",\"chargePointSerialNumber\":\"\",\"chargeBoxSerialNumber\":\"\",\"firmwareVersion\":\"\",\"iccid\":\"\",\"imsi\":\"\",\"meterType\":\"\",\"meterSerialNumber\":\"\"}]

[3, "e3ba4698-d64b-447e-81f5-0bf0e09700eb", {"status": "Accepted", "interval": 30, "currentTime": "2023-10-10T03:37:53Z"}]

2.5 代码

1.逻辑处理

/**
* 设备启动通知
* @param data
* @param msgId
* @param msgType
* @param action
* @param ip
* @return
*/
public ReturnData BootNotification(String data,String msgId,String msgType,String action,String ip,String body){
ReturnData returnData=new ReturnData();
try {
equHex=equHex.replaceAll("/","");
BootNotificationReq req=JSON.parseObject(data,BootNotificationReq.class);
String chargePointSerialNumber=req.getChargePointSerialNumber();//充电桩编号
log.info("sn的Hex{}",chargePointSerialNumber);
String states="Accepted";// 默认拒绝
BootNotificationConf conf=new BootNotificationConf();
String utcDateStr=DateUtil.localToUTC(new Date());

conf.setCurrentTime(utcDateStr); //过期时间
conf.setInterval(30);
conf.setStatus(states);

List resultList=new ArrayList();
resultList.add(Integer.parseInt(msgType)+1);
resultList.add(msgId);
resultList.add(conf);
String json = new ObjectMapper().writeValueAsString(resultList); //用此方法转为json字符串
returnData.setData(json);
returnData.setResult(true);
}catch (Exception e){
log.error("启动通知异常",e);
returnData.setResult(false);
}
return returnData;
}

2. BootNotificationReq
import lombok.Data;
/**
* 启动通知req
*/
@Data
public class BootNotificationReq {
//可选。它包含一个值,用来标识充电点内的充电箱的序列号。已弃用
//,将在未来的版本中被删除
private String chargeBoxSerialNumber;
//需要。这包含一个标识字符点模型的值。
private String chargePointModel;//充电桩模型
//可选。这其中包含一个标识充电点序列号的值。
private String chargePointSerialNumber;
//需要。这包含一个标识特征点的供应商的值
private String chargePointVendor;
//可选。这其中包含了充电点的固件版本
private String firmwareVersion;
//可选。其中包含调制解调器SIM卡的ICCID。
private String iccid;
//可选。其中包含调制解调器SIM卡的IMSI。
private String imsi;
//可选。其中包含充电点的主电表的序列号。
private String meterSerialNumber;
//可选。这包含了充电点的主电表的类型。
private String meterType;
}

3. BootNotificationConf

import lombok.Data;
/**
* 启动通知回复
*/
@Data
public class BootNotificationConf {
// Accepted 充电点已被中央系统接受。
//Pending 中央系统还没有准备好接受充电点。中央系统可以发送信息来检索信息或准备充电点。
// Rejected 中央系统不接受充电点。当中央系统不知道充电点id时,可能会发生这种情况以上翻译结果来自有道神经网络翻译(YNMT)· 通用场景
private String status;
//需要。这包含了中央系统的当前时间。
private String currentTime;
//需要。当接受注册状态时,它包含以秒为单位的心跳间隔。如果中央系统返回的不
//是“接受”,则间隔字段的值表示发送下一个引导通知请求之前的最小等待时间
private Integer interval;
}

3、心跳-HeartBeat

3.1 说明

为了让中央系统知道充电点仍处于连接状态,充电点会在可配置的时间间隔后发送心跳信息。
充电点应发送 Heartbeat.req PDU,以确保中央系统知道充电点还活着。
收到 Heartbeat.req PDU 后,中央系统应响应 Heartbeat.conf 。响应 PDU 应包含中央系统的当前时间,建议充电点使用该时间同步其内部时钟。
当另一个 PDU 已在配置的心跳时间间隔内发送到中央系统时,充电点可以跳过发送 Heartbeat.req PDU。这意 味着只要收到 PDU,中央系统就应该认为充电点是可用的,就像它收到 Heartbeat.req PDU 时一样。
注意:对于 WebSocket 上的 JSON,发送心跳并不是强制性的。不过,为了实现时间同步,建议至少每24 小时发送一次心跳。

3.2 Heartbeat.req

未定义字段

3.3 Heartbeat.conf

 它包含中央系统为响应 Heartbeat.req PDU 而发送给充电点的 Heartbeat.conf PDU 的字段定义。

中文

英文

3.4 JSON格式

[SEND ->] [2,"QsGAIVnh39SDvmzg","Heartbeat",{}]


[RECV <-] [3,"QsGAIVnh39SDvmzg",{"currentTime":"2023-05-17T14:26:10.306+08:00"}]

3.5 代码

1、逻辑

/**
* 设备心跳
* @return
*/
public ReturnData equheartbeat(String data,String msgType,
String msgId,String action,String ip,String body) {
ReturnData returnData = new ReturnData();
try {
log.info("设备心跳{}",data);
if(null!=ip && !"".equals(ip)){
List resultList=new ArrayList();
resultList.add(Integer.parseInt(msgType)+1);
resultList.add(msgId);
Map<String,Object> map=new HashMap<>();
Heartbeat heartbeat=new Heartbeat();
String utcStr=DateUtil.localToUTC(new Date());
heartbeat.setCurrentTime(utcStr);

map.put(action,heartbeat);
resultList.add(heartbeat);
returnData.setData(JSON.toJSONString(resultList));
returnData.setResult(true);
}
}else{
returnData.setMsg("设备心跳异常,无法获取ip");
returnData.setCode("111111");
returnData.setResult(false);
return returnData;
}
} catch (Exception e) {
returnData.setMsg("设备心跳异常"+e);
returnData.setCode("111111");
returnData.setResult(false);
e.printStackTrace();
}
return returnData;
}

2、Heartbeat

import lombok.Data;
/**
* 设备心跳
*/
@Data
public class Heartbeat {
        private String currentTime;
}

4、状态通知-StatusNotification

4.1 说明

充电点向中央系统发送通知,告知中央系统充电点的状态变化或错误。下表描述了充电点可能向中央系统发送 StatusNotification.req PDU 时从先前状态(左列)到新状态(上行)的变化。
注意:
OCPP 以前版本中定义的 " 占用 状态 "已不再适用。 占用状态状态分为五个新状态:准备状态、充电状态、暂停 EV 状态、暂停 EVSE 状态 和 完成。
状态通知中使用的是 EVSE,而不是插座或充电桩,以便将来兼容。

4.2 StatusNotification.req

其中包含充电点发送到中央系统的 StatusNotification.req PDU 的字段定义。
中文
英文

4.3 StatusNotification.conf

其中包含中央系统为响应 StatusNotification.req PDU 而向充电点发送的 StatusNotification.conf PDU 的字段定义。
未定义字段。

4.4 JSON格式

插枪
[SEND ->] [2,"I5622jdZvMI5nrqc","StatusNotification",{"connectorId":1,"errorCode":"NoError","status":"Preparing","timestamp":"2023-08-14T05:31:03Z"}]

[RECV <-] [3,"I5622jdZvMI5nrqc","{}"]

拔枪

[SEND ->] [2,"5KaXyxFzqamWjDJ3","StatusNotification",{"connectorId":1,"errorCode":"NoError","status":"Available","timestamp":"2023-08-14T06:47:10Z"}]

[3,"5KaXyxFzqamWjDJ3","{}"]

4.5 代码

通用方法

1、转换时间为UTC格式

public static String localToUTC(Date localDate) {
  long localTimeInMillis=localDate.getTime();
  /** long时间转换成Calendar */
  Calendar calendar= Calendar.getInstance();
  calendar.setTimeInMillis(localTimeInMillis);
  /** 取得时间偏移量 */
  int zoneOffset = calendar.get(java.util.Calendar.ZONE_OFFSET);
  /** 取得夏令时差 */
  int dstOffset = calendar.get(java.util.Calendar.DST_OFFSET);
  /** 从本地时间里扣除这些差量,即可以取得UTC时间*/
  calendar.add(java.util.Calendar.MILLISECOND, -(zoneOffset + dstOffset));
  /** 取得的时间就是UTC标准时间 */
  Date utcDate=new Date(calendar.getTimeInMillis());
  SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");
  String timeStr=df.format(utcDate);
  return timeStr;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1100619.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

华为OD机试 - 热点网站统计 - 逻辑分析(Java 2023 B卷 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷&#xff09;》…

【C++】缺省参数与函数重载

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 前言 本篇文章博主将带你学习缺省参数与函数重载&…

京东API接口带你了解京东工业|电商及供应链服务

京东工业赴港上市&#xff0c;带着非常优秀的成绩。 招股书显示&#xff0c;2022年实现交易额223亿元&#xff0c;营收141亿元&#xff0c;调整后净利润7亿元。短短六年时间&#xff0c;已成为中国工业供应链技术与服务市场领导者。京东API接口接入调取京东商品详情&#xff0c…

零基础怎么样才能学好 Python?Python 入门必看

Python 目前可以用一个字来描述那就是 “火”&#xff0c;问题来了&#xff0c;这么火的语言零基础小白到底该怎样学习 Python&#xff1f; 首先&#xff0c;从基础开始学习&#xff0c;切勿毛躁。 刚开始学习 Python 的时候&#xff0c;我们可能会有些毛躁总觉得这些知识太简…

南美委内瑞拉市场最全分析开发攻略,收藏一篇就够了

委内瑞拉是一个常被国内跨境商家忽略但具有巨大潜力的市场。尽管委内瑞拉的网络基础建设水平较低&#xff0c;网络速度受限&#xff0c;但委内瑞拉网络渗透率较佳。因为长期受美国制裁&#xff0c;所以经济发展水平较低&#xff0c;很多产品依赖进口&#xff0c;市场潜力还是非…

睿趣科技:抖音短视频带货素材哪里找

随着抖音短视频的火爆&#xff0c;越来越多的商家开始利用抖音进行产品推广和销售。而制作一部成功的抖音短视频&#xff0c;除了需要有吸引人的内容和创意外&#xff0c;还需要有高质量的素材。那么&#xff0c;抖音短视频带货素材应该去哪里找呢? 首先&#xff0c;我们可以从…

将excel表中的英文自动翻译成中文

某乎上垃圾内容太多&#xff0c;要么是复制粘贴的youdao翻译&#xff0c;要么是某网络函数库的软广。这里提供office的原生方法&#xff0c;需要用到word&#xff08;不适合数据量太大的情况&#xff09; 方法 复制需要翻译的列到word选择审阅 -> 翻译 -> 翻译文档 -&g…

掌控安全Update.jsp SQL注入

0x01 漏洞介绍 亿赛通电子文档安全管理系统是国内最早基于文件过滤驱动技术的文档加解密产品之一&#xff0c;保护范围涵盖终端电脑&#xff08;Windows、Mac、Linux系统平台&#xff09;、智能终端&#xff08;Android、IOS&#xff09;及各类应用系统&#xff08;OA、知识管理…

【精华系列】跟着Token学习数据挖掘-1

Hello&#xff0c;大家好&#xff01;这里是Token的博客&#xff0c;欢迎您的到来 今天整理的笔记时数据挖掘方向的基础入门&#xff0c;了解数据分析使用的一些基础的Python库&#xff0c;为后面的数据处理做好准备 01-数据分析工具介绍 准备&#xff1a;Python的安装、平台搭…

PTE-精听学习(一)

目录 SST SST每一题都是单独计时 MMA 切换题目的时候&#xff0c;总是会迷茫 deduct 出现关键词之后&#xff0c;才开始精听 没有人管你 &#xff0c;绝对是要为后方留出更多的时间 &#xff0c;选多一个错的&#xff0c;要倒扣分 特征 1.paraphrase 2.循序出现 …

MySQLJDBC入门与SQL注入

MySQL-JDBC入门与SQL注入 一.JDBC概述 1.JDBC 在Java语言中提供对数据库访问的支持Sun公司于1996年提供了一套访问数据库的标准Java类库JDBCJDBC的全称是Java数据库连接(Java Database Connectivity)它是一套用于执行 SQL语句的Java API应用程序可通过这套API连接到关系数据…

Python中的List

一、List(列表) 1、什么是 List (列表) List (列表)是 Python 内置的一种数据类型。 它是一种有序的集合,可以随时添加和删除其中的元素。 那为什么要有 List (列表)呢? 我们用一个例子来说明。 现在有一个团队要出去玩,要先报名。如果用我们之前学过的知识,那…

太强了!三种方案优化 2000w 数据大表!

目录 评估表数据体量 表容量&#xff1a; 磁盘空间 实例容量 出现问题的原因 如何解决单表数据量太大&#xff0c;查询变慢的问题 方案一&#xff1a;数据表分区 方案二&#xff1a;数据库分表 水平分表 垂直分表 1.取模方案&#xff1a; 2.range 范围方案 3.hash…

儿童口腔卫生:建立健康微笑的基石

引言 儿童口腔卫生是维护健康的关键部分&#xff0c;它不仅影响口腔健康&#xff0c;还对全身健康产生必然影响。本文将探讨一些儿童口腔卫生的重要性以及儿童的关键注意事项&#xff0c;以帮助家长和监护人确保儿童拥有健康的口腔。 第一部分&#xff1a;儿童口腔卫生的重要性…

Hudi第四章:集成Hive

系列文章目录 Hudi第一章&#xff1a;编译安装 Hudi第二章&#xff1a;集成Spark Hudi第二章&#xff1a;集成Spark(二) Hudi第三章&#xff1a;集成Flink Hudi第四章&#xff1a;集成Hive 文章目录 系列文章目录前言一、环境准备1.拷贝jar包 二、Flink集成hive1.配置模版2.案…

优雅而高效的JavaScript——Proxy 和 Reflect

&#x1f914;博主&#xff1a;小猫娃来啦 文章核心&#xff1a;优雅而高效的JavaScript——Proxy 和 Reflect 文章目录 Proxy 和 Reflect是什么Proxy创建 Proxy 对象拦截器方法拦截器示例&#xff1a;属性拦截拦截器示例&#xff1a;方法拦截 ReflectReflect 的静态方法Reflec…

ORACLE内存结构

内存体系结构 数据库由磁盘文件构成&#xff0c;当数据库启动时&#xff0c;相关实例将被启动&#xff0c;而实例由内存结构和进程组成。数据库及其运行的程序存放在分配给内存的不同结构当中。我们只讨论单实例的内存体系结构。内存跟磁盘空间分配一样&#xff0c;一般情况下…

Golang 面向对象编程 多态

基本介绍 变量(实例)具有多种形态。面向对象的第三大特征&#xff0c;在Go语言&#xff0c;多态特征是通过接口实现的&#xff08;接口能够体现多态的特征&#xff09;。可以按照统一的接口来调用不同的实现。这时接口变量就呈现不同的形态。 在前面的Usb接口案例&#xff0c;u…

金融行业的CFA、CPA和FRM你了解吗?中国人民大学与加拿大女王大学金融硕士需要吗?

CFA、CPA和FRM是金融行业中非常重要的专业资格认证&#xff0c;它们分别代表着不同领域的专业知识和技能。在当下越来越多的高校在把关金融硕士的申请过程中&#xff0c;拥有CFA、CPA和FRM都属于强大的加分项&#xff0c;中国人民大学与加拿大女王大学金融硕士也不例外&#xf…

软件工程与计算总结(十六)详细设计的设计模式

一.设计模式基础 某种意义上来说&#xff0c;设计模式就是设计经验的总结~ 设计模式不是简单的经验总结&#xff0c;更不是无中生有&#xff0c;它是经过实践反复检验、能解决关键技术难题、有广泛应用前景和能够显著提高软件质量的有效的经验总结。 每个模式都不是独立的&a…