gpt4 book ai didi

java - Playorm java.lang.Integer 无法转换为 java.math.BigInteger

转载 作者:行者123 更新时间:2023-12-01 04:24:35 25 4
gpt4 key购买 nike

我尝试基于 A basic ad hoc query example 构建一个基本的即席查询示例.

但是,我无法插入整数值。我认为是因为这段代码:

private Class getStorageTypeAsClass() {
switch (getStorageType())
{
case STRING:
return String.class;
case INTEGER:
return BigInteger.class;
}
}

我的代码:

package playorm;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.UUID;

import com.alvazan.orm.api.base.Bootstrap;
import com.alvazan.orm.api.base.DbTypeEnum;
import com.alvazan.orm.api.base.NoSqlEntityManager;
import com.alvazan.orm.api.base.NoSqlEntityManagerFactory;
import com.alvazan.orm.api.z3api.NoSqlTypedSession;
import com.alvazan.orm.api.z8spi.KeyValue;
import com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta;
import com.alvazan.orm.api.z8spi.meta.DboColumnIdMeta;
import com.alvazan.orm.api.z8spi.meta.DboDatabaseMeta;
import com.alvazan.orm.api.z8spi.meta.DboTableMeta;
import com.alvazan.orm.api.z8spi.meta.TypedColumn;
import com.alvazan.orm.api.z8spi.meta.TypedRow;

public class PlayOrm {
private static NoSqlEntityManager mgr;

@SuppressWarnings({ "unchecked", "rawtypes" })
public static void main(String[] args) {

Map properties = new HashMap();
properties.put(Bootstrap.AUTO_CREATE_KEY, "create");

String clusterName = "Test Cluster";
String seeds = "localhost:9160";
String keyspace = "nosql";

Bootstrap.createAndAddBestCassandraConfiguration(properties, clusterName, keyspace, seeds);
NoSqlEntityManagerFactory factory = Bootstrap.create(DbTypeEnum.CASSANDRA, properties,null,null);
mgr = factory.createEntityManager();
DboDatabaseMeta metaDb = mgr.find(DboDatabaseMeta.class,
DboDatabaseMeta.META_DB_ROWKEY);
DboTableMeta meta = new DboTableMeta();
meta.setup(null, "MyEntity", false);
metaDb.addMetaClassDbo(meta);

DboColumnIdMeta idMeta = new DboColumnIdMeta();
idMeta.setup(meta, "idField", String.class, true);
mgr.put(idMeta);

DboColumnCommonMeta fieldDbo = new DboColumnCommonMeta();
fieldDbo.setup(meta, "firstname", String.class, true, false);
mgr.put(fieldDbo);
DboColumnCommonMeta fieldDbo2 = new DboColumnCommonMeta();
fieldDbo2.setup(meta, "lastname", Integer.class, true, false);
mgr.put(fieldDbo2);

mgr.put(meta);
mgr.flush();

NoSqlTypedSession session = mgr.getTypedSession();
for (int i = 0; i < 10000; i++) {
TypedRow typedRow = session.createTypedRow("MyEntity");
typedRow.addColumn("firstname", "harry");
//**THE PROBLEM**
typedRow.addColumn("lastname", new Integer(i));
typedRow.setRowKey(UUID.randomUUID().toString());

session.put("MyEntity", typedRow);

if(i > 1000 && (i % 10) == 0 ){
session.flush();
mgr.clear();
}

}
session.flush();

}

没有返回 Integer.class 的选项。因此,它无法构造整数转换器:

Exception in thread "main" java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.alvazan.orm.impl.meta.data.NoSqlProxyImpl.invoke(NoSqlProxyImpl.java:96)
at com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta_$$_javassist_1.convertToStorage2(DboColumnCommonMeta_$$_javassist_1.java)
at com.alvazan.orm.api.z8spi.meta.TypedRow.addColumn(TypedRow.java:99)
at playorm.PlayOrm.main(PlayOrm.java:62)
Caused by: java.lang.ClassCastException: java.lang.Integer cannot be cast to java.math.BigInteger
at com.alvazan.orm.api.z8spi.conv.Converters$BigIntegerConverter.convertToNoSqlImpl(Converters.java:89)
at com.alvazan.orm.api.z8spi.conv.Converters$BaseConverter.convertToNoSql(Converters.java:138)
at com.alvazan.orm.api.z8spi.meta.DboColumnMeta.convertToStorage2(DboColumnMeta.java:167)
at com.alvazan.orm.api.z8spi.meta.DboColumnCommonMeta_$$_javassist_1._d8convertToStorage2(DboColumnCommonMeta_$$_javassist_1.java)
... 8 more

最佳答案

TypedRow 是一种特殊的 api,现在允许 BigInteger、BigDecimal 和 String 类型......但是,这些类型在存储时会存储为可能的最低字节,因此 int 值 10 会存储为一个字节。

出于好奇,为什么不使用带有 @NoSqlEntity 注释的 MyEntity.java 类呢???就您而言,使用 POJO 似乎更有益。

MyEntity.java 可以有任何原始类型,int、double 等等

我们认为您正在使用这些实体,因为大多数人都使用这些实体来加快开发速度。

后来,院长

关于java - Playorm java.lang.Integer 无法转换为 java.math.BigInteger,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18614447/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com