我的项目的目的是我想制作一张词汇卡。应用程序将为您提供一个英语单词,并且在英语单词下方有 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()
方法,然后扫描列表以创建两个单独的数组 eng
和turk
.
然后随机选择 4 个整数(例如 0,1,2,3
),并访问这些位置以在 textView 中设置文本(也可以使用其中之一来检索英文单词)。
如果我不明白您的请求,请告诉我!
关于java - 数据库中的数据如何在不同的 Activity 中分配给数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42011570/