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

相关内容

热门资讯

透视工具!微扑克有辅助透视,微... 透视工具!微扑克有辅助透视,微扑克ai辅助神器,系统教程(一向真的是有挂);无聊就玩这款微扑克有辅助...
透视最新!aapoker辅助,... 透视最新!aapoker辅助,aapoker透明挂真假,2025教程(从来真的有挂);人气非常高,a...
透视模拟器!智星德州菠萝辅助器... 透视模拟器!智星德州菠萝辅助器推荐,智星德州菠萝辅助器免费下载,靠谱教程(好像真的是有挂);透视模拟...
透视插件!wpk透视挂会被封号... 您好,wpk透视挂会被封号吗这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多...
透视黑科技!红龙扑克辅助器第一... 透视黑科技!红龙扑克辅助器第一视角,红龙扑克机制,wpk教程(原生是真的有挂);透视黑科技!红龙扑克...
透视智能ai!微扑克如何让系统... 您好,微扑克如何让系统发好牌这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多...
透视安卓版!德扑ai软件购买,... 透视安卓版!德扑ai软件购买,德扑之星软件辅牌器,解密教程(好像是真的有挂)1、金币登录送、破产送、...
透视系统!wepoke怎么看有... 透视系统!wepoke怎么看有没有外挂,wepoke ai辅助,细节方法(往昔真的是有挂);致您一封...
透视教学!微扑克数据采集,微扑... 透视教学!微扑克数据采集,微扑克ai辅助神器,必胜教程(竟然真的有挂);无聊就玩这款微扑克ai辅助神...
透视黑科技!德扑之星辅助器,德... 透视黑科技!德扑之星辅助器,德扑之星辅助工具,力荐教程(原来是真的有挂)是一款可以让一直输的玩家,快...