使用带有libgdx的iOS(robovm)sqlite数据库

时间:2014-06-17 14:54:47

标签: ios sqlite libgdx robovm

我有一个 libgdx 项目(Android),我使用 sqlite数据库。 我在 iOS 版本(robovm)中开发了相同的项目,我无法找到有关iOS版本的sqlite或数据库的任何内容。

是否可以使用相同的sqlite数据库?

感谢。

2 个答案:

答案 0 :(得分:2)

我知道这是一个老线程,但这对我有用

你当然不必这样做,但这就是我做的方式

首先,我为SQLite创建了一个名为.. SQLiteHelper的帮助器类 这会初始化事情

package com.hamzahrmalik.mitto.sqlite;

import java.io.File;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import SQLite.JDBCDriver;

import com.hamzahrmalik.mitto.utils.Util;

public class SQLiteHelper {

    private String DATABASE_NAME;
    private JDBCDriver driv;
    private Connection connection;

    final String DB_PATH = new File(System.getenv("HOME"), "Library/")
            .getAbsolutePath();

    public SQLiteHelper(String DATABASE_NAME) {
        this.DATABASE_NAME = DATABASE_NAME;
        driv = new JDBCDriver();
        try {
            connection = driv.connect("sqlite:/" + DB_PATH + this.DATABASE_NAME, null);
        } catch (SQLException e) {
        }
    }

    public void execUpdate(String sql) {
        Util.log("Running SQL " + sql);
        try {
            Statement statement = connection.createStatement();
            statement.executeUpdate(sql);
            //connection.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public ResultSet execQuery(String query) {
        Util.log("Running SQL query " + query);
        try {
            Statement statement = connection.createStatement();
            ResultSet rs = statement.executeQuery(query);
            return rs;
        } catch (SQLException e) {
            return null;
        }
    }

}

然后每个数据库扩展此类 例如,我有一个消息数据库

我创建了一个SQLiteMessages类,它扩展了我制作的Helper类

然后在构造函数中我创建表

final String CREATE_MESSAGES_TABLE = "CREATE TABLE IF NOT EXISTS "
                + this.phonenum + "(" + KEY_ID
                + " INTEGER PRIMARY KEY NOT NULL," + KEY_MESSAGE + " TEXT,"
                + KEY_FROM + " TEXT," + KEY_TO + " TEXT," + KEY_DATE + " TEXT,"
                + KEY_STATUS + " INTEGER)";

        execUpdate(CREATE_MESSAGES_TABLE);

然后我可以在SQL中正常添加,删除和更新

public void addMessage(Message m) {
        final String ADD_MESSAGES = "INSERT into " + phonenum + " VALUES('"
                + m.getId() + "','" + m.getMessage() + "', '" + m.getSender()
                + "', '" + m.getRecipient() + "', '"
                + Util.formatDate(m.getTime()) + "', '" + m.getStatus()
                + "')";
        execUpdate(ADD_MESSAGES);
    }

显然你需要一个Message对象,但这与问题

并不真正相关

简单地检索数据:

public Message getMessage(int id) {
        ResultSet rs = execQuery("SELECT * FROM " + phonenum + " WHERE "
                + KEY_ID + " = " + String.valueOf(id));
        try {
            if (rs.next()) {
                Message m = messageFromResult(rs);
                return m;
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return null;
    }

public Message messageFromResult(ResultSet rs) {
        try {
            return new Message(rs.getInt(KEY_ID), rs.getString(KEY_MESSAGE),
                    rs.getString(KEY_FROM), rs.getString(KEY_TO),
                    Util.parseDate(rs.getString(KEY_DATE)),
                    rs.getInt(KEY_STATUS));
        } catch (SQLException e) {
            e.printStackTrace();
            return null;
        }
    }

此处不需要外部库 请记住将此添加到您的robovm.xml

<forceLinkClasses>
    <pattern>SQLite.**</pattern>
</forceLinkClasses>

答案 1 :(得分:1)

没有关于如何在RoboVM上使用SQLite的文档(至少我知道)。以下链接可能很有用:

  1. https://groups.google.com/forum/#!topic/robovm/5KF_nQJqHR8
  2. Does Android Support JDBC