Android Studio - 从SQLite数据库加载RecyclerView,在EditText中输入一个单词。
创始人
2024-08-15 22:00:26
0

以下是一个使用SQLite数据库加载RecyclerView,并在EditText中输入一个单词的Android Studio示例代码:

  1. 首先,在你的项目中添加以下依赖项到你的app的build.gradle文件中:
dependencies {
    implementation 'androidx.recyclerview:recyclerview:1.2.1'
    implementation 'androidx.sqlite:sqlite:2.1.0'
}
  1. 创建一个名为Word的Java类,用于表示数据库中的单词:
public class Word {
    private int id;
    private String word;

    public Word(int id, String word) {
        this.id = id;
        this.word = word;
    }

    public int getId() {
        return id;
    }

    public String getWord() {
        return word;
    }
}
  1. 创建一个名为DatabaseHelper的Java类,用于管理SQLite数据库:
public class DatabaseHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "words.db";
    private static final int DATABASE_VERSION = 1;
    private static final String TABLE_NAME = "words";
    private static final String COLUMN_ID = "id";
    private static final String COLUMN_WORD = "word";

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

    @Override
    public void onCreate(SQLiteDatabase db) {
        String createTable = "CREATE TABLE " + TABLE_NAME + " (" +
                COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                COLUMN_WORD + " TEXT)";
        db.execSQL(createTable);
    }

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

    public void insertWord(String word) {
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues contentValues = new ContentValues();
        contentValues.put(COLUMN_WORD, word);
        db.insert(TABLE_NAME, null, contentValues);
        db.close();
    }

    public List getAllWords() {
        List wordList = new ArrayList<>();
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery("SELECT * FROM " + TABLE_NAME, null);

        if (cursor.moveToFirst()) {
            do {
                int id = cursor.getInt(cursor.getColumnIndex(COLUMN_ID));
                String word = cursor.getString(cursor.getColumnIndex(COLUMN_WORD));
                Word newWord = new Word(id, word);
                wordList.add(newWord);
            } while (cursor.moveToNext());
        }

        cursor.close();
        db.close();

        return wordList;
    }
}
  1. 创建一个名为WordAdapter的Java类,用于将单词列表显示在RecyclerView中:
public class WordAdapter extends RecyclerView.Adapter {
    private List wordList;

    public class WordViewHolder extends RecyclerView.ViewHolder {
        public TextView wordTextView;

        public WordViewHolder(View view) {
            super(view);
            wordTextView = view.findViewById(R.id.wordTextView);
        }
    }

    public WordAdapter(List wordList) {
        this.wordList = wordList;
    }

    @Override
    public WordViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View itemView = LayoutInflater.from(parent.getContext())
                .inflate(R.layout.word_item, parent, false);
        return new WordViewHolder(itemView);
    }

    @Override
    public void onBindViewHolder(WordViewHolder holder, int position) {
        Word word = wordList.get(position);
        holder.wordTextView.setText(word.getWord());
    }

    @Override
    public int getItemCount() {
        return wordList.size();
    }
}
  1. res/layout目录下创建一个名为activity_main.xml的XML布局文件,用于显示RecyclerView和EditText:


    

    
  1. res/layout目录下创建一个名为`word_item

相关内容

热门资讯

wepoke模拟器!wepok... wepoke模拟器!wepoke有科技吗,wepoke软件收费是真的,扑克教程(有挂教程);致您一封...
微扑克ai机器人!wepoke... 微扑克ai机器人!wepoke辅助透视教程,德州aa poker有外挂,软件教程(有挂辅助挂)1、构...
德州微扑克辅助!wpk微扑克真... 德州微扑克辅助!wpk微扑克真的有挂吗,德州软件工具,德州论坛(有挂辅助挂),您好,德州微扑克辅助这...
wepok软件透明挂!德扑统计... wepok软件透明挂!德扑统计软件,德州辅助神器wpk,2025新版总结(有挂透明)1、wepok软...
智星德州菠萝有挂吗!微扑克有规... 智星德州菠萝有挂吗!微扑克有规律吗,德州ai智能系统,透明挂教程(有挂技巧)您好,智星德州菠萝有挂吗...
wepower辅助器!德州之星... wepower辅助器!德州之星app辅助器怎么用,wpk透视辅助哪里下载,规律教程(有挂黑科技)是一...
wepokeai代打!微扑克系... wepokeai代打!微扑克系统的发牌速度有多快,红龙扑克是真是假,可靠技巧(有挂透明)1、许多玩家...
aapoker猫腻!德州ai机... aapoker猫腻!德州ai机器人免费测试,微扑克有计算器,技巧教程(有挂教学),您好,德州ai机器...
wepoke辅助有挂!aapo... wepoke辅助有挂!aapoker辅助是真的吗,wpk透视辅助封号,第三方教程(有挂教学);小薇(...
微扑克辅助机器人!aapoke... 微扑克辅助机器人!aapoker是正规的吗,(wEpoKe)原生真的是有挂(详细辅助玩家教你)1、完...