java - 使用 Activity 的 android 在 sql 上保存实际上并没有保存

标签 java android database activeandroid

我在 android 中使用 activeandroid 库的每个人都避免进行 sql 编码,但由于某种原因它不起作用

这是我的代码:

这是我的 list :

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

<application
    android:name=".MyApplication"
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme">

    <meta-data
        android:name="AA_DB_Name"
        android:value="knownFiles2.db"/>

    <meta-data
        android:name="AA_DB_Version"
        android:value="5"/>

    <activity
        android:name=".MainActivity"
        android:label="@string/app_name" >



        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

这是我的应用程序类

    public class MyApplication extends Application {
@Override
public void onCreate() {
    super.onCreate();

    ActiveAndroid.initialize(this);
}

这是文件夹模型

    @Table(name="Folders")
public class Folder extends Model implements Serializable{
@Column(name="Path")
public String path;

@Column(name = "ShowAllImages")
public String showAllImages;

Folder() {
    super();
}

Folder(String path, String showAllImages) {
    super();

    this.path = path;

    this.showAllImages = showAllImages;
}

@Override
public String toString() {
    return "Path: "+path+
            " ShowAllImages "+showAllImages;
}

这是服务器模型

    @Table(name = "Servers")
    public class Server extends Model implements Serializable{

@Column(name = "Ip")
String ip;

@Column(name = "Folder")
Folder folder;

Server() {
    super();
}

Server(String ip, Folder folder) {
    super();
    this.ip = ip;

    this.folder = folder;
}

@Override
public String toString() {

    return "Ip: "+ip+" Folder: "+folder.toString();
}

public List<Server> getServer() {
    return getMany(Server.class, "Ip");
}

这是我正在尝试运行的代码:

       Folder folder = new Folder("private/secret/","show-all-images.php");

                folder.save();

                Server server = new Server("192.168.1.191",
                        folder);
                server.save();

                Log.v("MyTag",server.getId()+"");

                Log.v("MyTag",server.toString());

                Log.v("MyTag","Added");

                ArrayList<Server> data = new Select()
                        .all()
                        .from(Server.class)
                        .execute();

                Log.v("MyTag", data.size()+"");
                for (Server serverLoop:data) {
                    Log.v("MyTag", serverLoop.toString());
                }

日志应该返回数据库中的所有元素,但没有,因为它说携带数据的arraylist的大小为0

这是日志: 04-09 22:59:30.824 27608- 27608/com.example.mariomarhuendabeltran.photokeeper V/MyTag:5 04-09 22:59:30.824 27608-27608/com.example.mariomarhuendabeltran.photokeeper V/MyTag:IP:192.168.1.191 文件夹:路径:private/secret/ShowAllImages show-all-images.php 04-09 22:59:30.824 27608-27608/com.example.mariomarhuendabeltran.photokeeper V/MyTag:已添加 04-09 22:59:30.824 27608-27608/com.example.mariomarhuendabeltran.photokeeper V/MyTag:0

可以看到添加成功,但是列表是空的。 5表明刚刚添加的元素是数据库中的第五个

请帮忙!! 提前致谢

最佳答案

您还需要在 list 中定义您的模型,

在您的 list 中添加:

<meta-data
    android:name="AA_DB_Name"
    android:value="knownFiles2.db"/>

<meta-data
    android:name="AA_DB_Version"
    android:value="5"/>

<meta-data
        android:name="AA_MODELS"
        android:value=".YourModel1, .YourModel2" />

希望对您有所帮助。 你代码的其他部分对我来说似乎没问题

关于java - 使用 Activity 的 android 在 sql 上保存实际上并没有保存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29549355/

相关文章:

java - 在每个单元测试后创建一个新的 bean 实例

android - 应用无法打开,打开跟踪文件报错

android - 将渐变应用于 android 中 ListView 中的行

mysql - SQL COUNT(*) 在 PostgreSQL 中不起作用,但在 MySQL 中不起作用

database - 将 csv 或文本文件导入数据库

java - 有没有办法在不选择 1 乘 1 的情况下按百分比减少一个值并增加同一个表中的其他值

java - Google map API 节点

java - 分散在多个类中的条件代码的设计模式代码

android - 带有皮肤的 BottomSheetDialogFragment 主题

sql - 数据库ERD循环查询