- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在学习使用 ORMLite。我有一个特定的用例,我不确定我正在寻找的功能是否存在于 ORMLite 中,或者我是否需要自己编写一些额外的代码。
这是一个基于 ORMLite 文档的示例。该文档使用 Account 对象,我可以执行返回某种 Collection 的各种查询:
// get our query builder from the DAO
QueryBuilder<Account, String> queryBuilder = accountDao.queryBuilder();
// the 'password' field must be equal to "qwerty"
queryBuilder.where().eq(Account.PASSWORD_FIELD_NAME, "qwerty");
// prepare our sql statement
PreparedQuery<Account> preparedQuery = queryBuilder.prepare();
// query for all accounts that have "qwerty" as a password
List<Account> accountList = accountDao.query(preparedQuery);
对于我的情况,我只对帐户中的单个列感兴趣 - 让我们假设它是“密码”列。该文档显示了如何使用 selectColumns(String... columns)
方法仅选择我想要的列。
selectColumns(String... columns)
Add columns to be returned by the SELECT query and set on any resulting objects. If no columns are selected then all columns are returned by default. For classes with id columns, the id column is added to the select list automagically. All fields not selected in the object with be their default values (null, 0, false, etc.).
但是此查询仍将返回 Account 对象的集合,其中几乎所有字段都包含默认值。这显然是自动垃圾收集的好处之一。由于我的密码实际上是字符串并且都可以这样解释,并且我想将此信息传递给其他真正不关心帐户是什么的类,我真正想要的是 Collection<String>
而不是Collection<Account>
。
现在已经不是我第一天编程了,所以我自己有多种方法来解决这个问题。我可以迭代一个帐户集合并从中构建一个新的字符串集合。我目前使用的一个更以 ORMLite 为中心的解决方案是构建一个自定义 RowMapper,它获取原始结果并仅返回数组 [0] 位置中的值。
然而,这让我想知道我是否遗漏了一些东西,因为我可能不是第一个需要简单对象集合而不是复杂对象集合的人,其中除了一个字段之外的所有字段都为空。我想知道 ORMLite 是否提供了一种更简单的方法来做到这一点,但我在研究中没有发现太多。
这样就不会成为“这个答案不算数,再给我一个”游戏,我的问题本质上是ORMLite 的哪些内置功能提供了这种便利?
最佳答案
what I would really like is a Collection instead of a Collection.
因此,大多数查询都是通过 DAO 完成的,返回由 DAO 管理的实体或实体集合。但是,您当然可以使用 raw-queries with ORMLite并返回您想要的任何内容。
所以你应该能够做类似的事情:
GenericRawResults<String> rawResults = orderDao.queryRaw("SELECT qwerty FROM accounts");
for (String result : rawResults) {
System.out.println("Account qwerty field = " + result);
}
rawResults.close();
关于java - 查询单列并返回值的集合而不是复杂的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34862436/
编辑:我似乎问错了这个问题。 我正在尝试寻找一种方法来查询一个集合是否在另一个集合中可用。例如: SELECT * FROM something WHERE (1, 3) IN (1, 2, 3, 4
这两种方法似乎 produce the same results ,但我一直很难真正说服人们第二种方法有效,因为它显然并不为人所知。 // Create some data var foo = { '
我一直在学习Kotlin,并且遇到过Collections API。在Kotlin之前,我一直在学习Java,并且我知道Java中有很多不同类型的Collections API。例如,我们使用List
为什么我会得到不同的行为: Collection col2 = new ArrayList(col); 集合 col2 = new ArrayList(); col2.addAll(col) 我正在与
所以我有一个代表专辑信息的 JSON 对象。给定“function updateRecords(id, prop, value)”我希望能够更新每个条目。正确的完成代码如下。 我得到了指示,粗体部分,
我想存储一个对象集合,这些对象根据它们所代表的值进行键控。这些键可以重复。例如: [4] => Bob [5] => Mary [5] => Sue [9] => Steve [10] =>
在检查 ArrayList API 时,我注意到一些看起来很奇怪的东西。 确实,这里是 ArrayList 构造函数实现,其中 Collection 作为参数传递: public ArrayList(
我正在为 API 编写一个 swagger 定义文件。 API 是用于 GET 请求的 /path/to/my/api: get: summary: My Custom API d
我知道scala.collection包中有两个非常有用的对象,可以帮助我们实现这个目标: JavaConverters(如果我想明确说明并准确说明我要转换的内容) JavaConversions(如
我已经阅读了无数其他帖子,但似乎无法弄清楚发生了什么,所以是时候寻求帮助了。 我正在尝试将包含集合的域实体映射到也包含集合的 dtos。 这是一个原始示例; (我提前为代码墙道歉,我尽量保持简短):
我正在创建一个具有 ArrayList 的类,因此当我调用构造函数时,它会初始化该数组: public class ElementsList { private ArrayList list;
我正在阅读事件指南和指南的开头,它说: You can also add an event listener to any element in the this.$ collection using
我是 Python 新手,想知道如何使用键在字典中存储不同数据类型的列表 例如 - {[Key1,int1,int1,String1] , [Key2,int2,int2,String2], [Key
int[] mylist = { 2, 4, 5 }; IEnumerable list1 = mylist; list1.ToList().Add(1); // why 1 does not get
我在 UI 表单中的每一行之后将以下内容添加到 HashMap 集合中 声明 Map> map = new HashMap>(); List valSetOne = new ArrayList();
我正在开发我的第一个 Java 项目,我有一个问题。问题应该很简单(虽然代码不是那么短,但没有理由被吓倒:))。我创建了一个基本的角色扮演游戏,并且有一个定义每个角色的抽象类“Character”。在
我正在开发一款应用程序,可以为用户收集推文、Facebook 状态和 Facebook 照片。目前,用户确切地设定了他们希望这种收获发生的时间和时间,并且蜘蛛会在此期间拉取数据。 when 和 to
有谁知道在 C# 中是否有与 Java 的 Set 集合等效的好方法?我知道您可以通过填充但忽略值来使用 Dictionary 或 HashTable 在某种程度上模仿集合,但这不是一种非常优雅的方式
EXISTS 该函数返回 集合中第一个元素的索引,如果集合为空,返回NULLNULLNULL Collecti
RDF集合是通过属性 rdf:parseType="Collection" 来描述仅包含指定成员的组 rdf:parseType="Collection" 属
我是一名优秀的程序员,十分优秀!