简体   繁体   English

ArangoDB Java驱动程序:将多个参数放入事务中

[英]ArangoDB Java Driver: put multiple parameters in transaction

I need to put multiple parameters in transaction in JAVA drived for ArangoDB; 我需要在ArangoDB驱动的JAVA中的事务中添加多个参数;

It works with single parameter: 它适用于单个参数:

public String save(User user) throws ArangoDBException {

    TransactionOptions options = new TransactionOptions().params(user).writeCollections(collectionName);
    String action = "function (params) { "
            + "var db = require('internal').db; "
            + "var doc = params;"
            + "db.users.save(doc);"
            + "}";

    return db.transaction(action, String.class, options);
}

But if I need to pass multiple parameters, then I'm stuck. 但是,如果我需要传递多个参数,那我就陷入困境。 Tried to pass map, arraylist or array, but it doesn't seem to work: 试图传递map,arraylist或array,但似乎不起作用:

public void save(User user, User user2) throws ArangoDBException {
    Map<String, Object> parameters = new MapBuilder()
            .put("user", user)
            .put("user2" user2)
            .get();


    TransactionOptions options = new TransactionOptions().params(parameters).writeCollections(collectionName);
    String action = "function (params) { "
            + "var db = require('internal').db; "
            + "var doc = params['user'];"
            + "var doc2 = params['user2'];"
            + "db.users.save(doc);"
            + "db.users.save(doc2);"
            + "}";

    db.transaction(action, String.class, options);
}

The need of your workaround is not necessary any more. 不再需要您的解决方法。 The missing automatic serialization of map/list/array within TransactionOptions was a bug in the java-driver which is fixed with version 4.1.5 TransactionOptions缺少的映射/列表/数组自动序列化是Java驱动程序中的一个错误,该错误已在版本4.1.5中修复

不得不序列化地图:

TransactionOptions().params(db.util().serialize(params)).writeCollections(collectionName, "users2");

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM