ORM Lite与ListView和Mysql后端的集成(Android)

3
我需要构建一个Android应用程序,该应用程序在ListView中显示数据库条目列表。我遇到了这个线程,并尝试了以下内容。
CloseableIterator<Parlor> iterator = new ParlorAsync().execute().get();
AndroidDatabaseResults adr = (AndroidDatabaseResults) iterator.getRawResults();
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
                R.layout.list_view_template,
                adr.getRawCursor(),
                new String[]{""},
                new int[]{R.id.parlor_name});
parlor_list.setAdapter(adapter);

在这里,parlor是一个实体,而ParlorAsync是一个AsyncTask,它处理与Mysql数据库的连接并返回数据库中的每一行:

JdbcConnectionSource source = new JdbcConnectionSource("jdbc:mysql://192.168.1.1:3306/mydatabase");
source.setUsername("user");
source.setPassword("password");
Dao<Parlor, Integer> parlorDao = DaoManager.createDao(source, Parlor.class);
QueryBuilder<Parlor, Integer> queryBuilder = parlorDao.queryBuilder();
queryBuilder.selectColumns("name");
queryBuilder.orderBy("name", true);
return parlorDao.iterator(queryBuilder.prepare());

正如您所看到的,我使用了JdbcConnectionSource,这就是问题的起源。现在它告诉我:

com.j256.ormlite.jdbc.JdbcDatabaseResults cannot be cast to com.j256.ormlite.android.AndroidDatabaseResults

这是list_view_template.xml文件。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".ParlorListView">

<TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="New Text"
        android:id="@+id/parlor_name" android:layout_alignParentTop="true" android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true" android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true"/>
</RelativeLayout>

这是我的Gradle依赖项。
compile group: 'com.j256.ormlite', name: 'ormlite-core', version: '4.48'
compile group: 'com.j256.ormlite', name: 'ormlite-jdbc', version: '4.48'
compile group: 'com.j256.ormlite', name: 'ormlite-android', version: '4.48'
compile group: 'mysql', name: 'mysql-connector-java', version: '5.1.6'

我做错了什么?

最好的祝福

1个回答

1
  1. 你的特定问题是试图将 DatabaseResults 接口强制转换为 AndroidDatabaseResults,希望它能够工作 - 结果表明它不行。
  2. 你的根本问题是试图从不可靠的 Iterator 中提取 Cursor

你应该从 ContentProvider 获取 Cursor,这必须使用 LoaderManager 加载,并且你的查询应该放在 ContentProviderquery() 方法所在的位置。


我该怎么做?我有一个外部的mysql数据库(不是本地的),我已经成功使用JdbcConnectionSource进行读写,但我仍然需要从这个JdbcConnectionSource获取一个Cursor... - LimitX
你应该使用CursorProvider来包装你的jdbc查询 - 就这样。 - Barmaley

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接