apache-spark - 编组不适用于 MarkLogic 中的 JAXBHandle
问题描述
我想将以下对象存储到 MarkLogic。
@XmlRootElement(name = "trainModel")
@XmlAccessorType(XmlAccessType.FIELD)
public class TrainedModel implements Serializable {
private static final long serialVersionUID = 1L;
private String modelName;
private CrossValidatorModel crossValidatorModel;
public String getModelName() {
return modelName;
}
public void setModelName(String modelName) {
this.modelName = modelName;
}
public CrossValidatorModel getCrossValidatorModel() {
return crossValidatorModel;
}
public void setCrossValidatorModel(CrossValidatorModel crossValidatorModel) {
this.crossValidatorModel = crossValidatorModel;
}
@Override
public String toString() {
return "TrainedModel [modelName=" + modelName + ", crossValidatorModel=" + crossValidatorModel + "]";
}
}
我正在使用 JAXBHandle 来完成我的要求,但是在将 TrainedModel 对象存储到 MarkLogic 时,CrossValidatorModel 变空了。
CrossValidatorModel 是由org.apache.spark.ml.tuning.CrossValidatorModel
.
我试过下面的代码,
CrossValidatorModel crossValidatorModel = createDataFrame(null);
TrainedModel trainedModel = new TrainedModel();
trainedModel.setModelName("sample");
trainedModel.setCrossValidatorModel(crossValidatorModel);
JAXBContext context = JAXBContext.newInstance(TrainedModel.class);
JAXBHandle<TrainedModel> jaxbHandle = new JAXBHandle<TrainedModel>(context);
jaxbHandle.set(trainedModel);
GenericDocumentManager docMgr = client.newDocumentManager();
docMgr.writeAs("/shivling.xml", null, jaxbHandle);
这是我得到的xml,
<?xml version="1.0" encoding="UTF-8"?>
<trainModel>
<modelName>sample</modelName>
<crossValidatorModel>
</crossValidatorModel>
</trainModel>
crossValidatorModel 在这里是空的,请帮我解决这个问题。
解决方案
NULL(在您的代码中)对 XML有影响:您的结果表明代码中存在语义问题。
JAXB 框架可以通过适当的 MarkLogic Document Manager 或旧的 POJO 方式交付:
一个简单的 MarkLogic JAXB 注释(您将在批量读取 | 写入事务中使用 DMSDK):
代码片段:
XMLDocumentManager docMgr = marklogic.newXMLDocumentManager();
TrainedModel trainedModel = new TrainedModel();
trainedModel.setModelName("History and Psychology");
trainedModel.setCrossValidatorModel("Biology");
String docId = "/train-model.xml";
docMgr.writeAs(docId, trainedModel);
低于标准的 IO 方法:
TrainedModel trainedModel = new TrainedModel();
trainedModel.setModelName("History and Current Affairs");
trainedModel.setCrossValidatorModel("Psychology");
// initialize JAXB
JAXBContext context = JAXBContext.newInstance(TrainedModel.class);
// POJO Handle
JAXBHandle<TrainedModel> writeHandle = new JAXBHandle<TrainedModel>(context);
// Marshalling
Marshaller jaxMar = context.createMarshaller();
String docId = "/train-model.xml";
// IsMarshalled
jaxMar.marshal(trainedModel, System.out);
// set Handle
writeHandle.set(trainedModel);
// write POJO to MarkLogic
docMgr.write(docId, writeHandle);
推荐阅读
- oracle - Oracle SQL:返回没有重复的集合
- java - 将 Json 文件反序列化为包含以对象为键的映射的 java 对象
- petri-net - Petri 网建模
- css - SVG 圆环图中段之间的间隙
- jquery - 我如何确定每个表的最高数字是多少
- javascript - 如何使用 XMLHttpRequest 在另一个 HTML 文件中显示 html 文件?
- javascript - 无法使用从 chlid 组件到父组件的数据?
- mysql - 尝试统计该在线用户正在处理的订单
- javascript - 在配置 react-native-maps 中获取 "supportLibVersion" 、 "playServicesVersion" 和 "androidMapsUtilsVersion" 值
- networking - 如何使用 calico 网络从节点访问 Kubernetes 服务