java - 数据库中的数据如何在不同的 Activity 中分配给数组?

标签 java android arrays android-sqlite

我的项目的目的是我想制作一张词汇卡。应用程序将为您提供一个英语单词,并且在英语单词下方有 4 个土耳其语单词(1 个单词是真实单词。Ex : hello= merhaba)。您将猜出真实的单词。我将使用 array 来做到这一点。我错了还是你想给我建议?
我一直在开发一个小项目。我想在不同的 Activity 中使用数据库中的数据。我的数据就像数据库中的数据:

ID  word   word_tr

1   hello  merhaba

2   hi     selam

...

我希望 assin 数据在不同的 Activity (WordsActivity)中排列

数组1

你好

...

数组2

梅尔哈巴

塞拉姆 ...

这是我的代码:

package de.murattekinlive.pwords;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import java.util.ArrayList;
import java.util.List;


public class DataBase extends SQLiteOpenHelper {
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_NAME = "DBWORDS";
private static final String TABLE_NAME  = "WTABLE";
private static final String ID  ="ID";
private static final String WORD   = "WORD";
private static final String WORD_TR1 = "TURKCE_1";


public DataBase(Context context){
    super(context,DATABASE_NAME,null,DATABASE_VERSION);
}

public DataBase(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
    super(context, name, factory, version);
}

@Override
public void onCreate(SQLiteDatabase db) {
    String CREATE_DBTABLE = "CREATE TABLE " + TABLE_NAME + "(" + ID +" INTEGER PRIMARY KEY AUTOINCREMENT," +WORD+
            " TEXT," +WORD_TR1+" TEXT" + "  )";
    db.execSQL(CREATE_DBTABLE);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    String TABLE_DELETE = "DROP TABLE IF EXISTS" + TABLE_NAME ;
    db.execSQL(TABLE_DELETE);
    onCreate(db);

}

    public long addRecord(Words words){
    SQLiteDatabase sqLiteDatabase = this.getWritableDatabase();
    ContentValues contentValues = new ContentValues();
    contentValues.put(WORD,words.getWORD());
    contentValues.put(WORD_TR1,words.getTR1());
    long status = sqLiteDatabase.insert(TABLE_NAME,null,contentValues);
    sqLiteDatabase.close();
    return status;
}
    public List<Words> allRecords(){
    List<Words> wordsList = new ArrayList<>();
    String sql_query = "SELECT *FROM " + TABLE_NAME;
    SQLiteDatabase sqLiteDatabase =this.getWritableDatabase();
    Cursor cursor =sqLiteDatabase.rawQuery(sql_query,null);
    if(cursor.moveToFirst()){
        Words words =null;
        do{
            words = new Words();
            words.setID(cursor.getInt(0));
            words.setWORD(cursor.getString(1));
            words.setTR1(cursor.getString(2));
            wordsList.add(words);
        }while (cursor.moveToNext());
    }
    return wordsList;
}

public String getRandomQuote(){
    SQLiteDatabase sqLiteDatabase = this.getWritableDatabase();
    Cursor cursor = sqLiteDatabase.query(TABLE_NAME + " ORDER BY RANDOM() LIMIT 1",new String[]
            {WORD,WORD_TR1},null,null,null,null,null);
    if(cursor.moveToFirst()){
        return
          cursor.getString(cursor.getColumnIndex(WORD))+
         cursor.getString(cursor.getColumnIndex(WORD_TR1));

    }
    else
        return "nothing";
}

}

我的wordActivity(我想用数据完成所有任务)

package de.murattekinlive.pwords;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;

import java.util.List;

public class WordsActivity extends AppCompatActivity {
TextView textView;



@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_words);
    textView = (TextView) findViewById(R.id.textView);
    Intent intent = getIntent();
    String random = intent.getStringExtra("random"); // this is just test...
    textView.setText("Number : " + random);


}

}

最佳答案

我不知道我是否理解了这个问题,但是如果您想要数据库中每个单词都有两个数组,只需调用 allRecords()方法,然后扫描列表以创建两个单独的数组 engturk .

然后随机选择 4 个整数(例如 0,1,2,3 ),并访问这些位置以在 textView 中设置文本(也可以使用其中之一来检索英文单词)。

如果我不明白您的请求,请告诉我!

关于java - 数据库中的数据如何在不同的 Activity 中分配给数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42011570/

相关文章:

java - android:background不适用于Theme.MaterialComponents

java - 如何在 Android 上管理位图的内存?

Android - 在布局边缘居中 ImageView

javascript - 解析ffmpeg信息的正则表达式

c - 对带有数组和嵌套 For 循环的程序中特定语句的作用感到困惑

c# - 包含数组的 JSON 上的 JavaScriptSerializer

java - 使 Eclipse 鼓励特定的关键字顺序

java - 我应该删除Android应用程序内存中的文件吗?

java - 如何将 ActionBarActivity 作为 Intent 传递?

android - 自定义 Android 日历 View