gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-10-30 23:45:18 25 4
gpt4 key购买 nike

我在 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:504-09 22:59:30.824 27608-27608/com.example.mariomarhuendabeltran.photokeeper V/MyTag:IP:192.168.1.191 文件夹:路径:private/secret/ShowAllImages show-all-images.php04-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/

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