0321-SQLite的用法---新建数据库、对数据的增、删、改、查

学习SQLite首先要认识SQLite,那么什么是SQLite呢?

1. SQLite数据库存储是Android系统提供的数据存储方式之一
2. SQLite是专为嵌入式设备设计的一款轻量级数据库
3. SQLite占用资源非常低,在嵌入式设备中,只需要几百K的内存
4. SQLite支持标准的SQL语法,遵循数据库的ACID事务
5. SQLite是android系统自带,不需要单独安装,不需要用户名密码就可以使用

关于SQLiteOpenHelper类:

SQLiteOpenHelper是系统提供的一个管理数据库表创建和版本管理(尤其是版本更新)的抽象类,我们必须通过继承SQLiteOpenHelper来实现自己的工具类。 一般我们要重写三个方法,构造器、onCreate方法、onUpgrade方法。
onCreate方法只会在第一次创建数据库时执行,只会执行一次。

SQLite的使用:

使用SQLite创建数据库和数据表:
1.新类继承SQLiteOpenHelper;
2.实现构造方法;
3.重写onCreate方法;
4.重写onUpgrade方法
5.实例化SQLiteOpenHelper的子类对象;
6.调用getWritableDatabase方法或者getReadableDatabase方法;
使用使用SQLite创建数据库和数据表实例,创建一个Student.db数据库,创建一个student表。
//新类继承SQLiteOpenHelper;
 public class MyDatabaseHelper extends SQLiteOpenHelper {
   

        private Context mContext;
        //实现构造方法;
        public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
            super(context, name, factory, version);
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这个问题涉及到安卓开发的多个方面,我会分步骤地回答你。 首先,我们需要在安卓项目中添加SQLite依赖库,你可以在app模块的build.gradle文件中添加以下代码: ```gradle dependencies { //... implementation 'androidx.sqlite:sqlite:2.2.0' } ``` 接着,我们需要创建SQLite数据库和表,在你的项目中新建一个Java类,比如叫做MyDatabaseHelper,然后在该类中重写onCreate()和onUpgrade()方法,分别实现数据库的创建和升级。具体代码如下: ```java public class MyDatabaseHelper extends SQLiteOpenHelper { private static final String DB_NAME = "my_database"; private static final int DB_VERSION = 1; private static final String TABLE_NAME = "my_table"; private static final String COLUMN_ID = "_id"; private static final String COLUMN_NAME = "name"; private static final String COLUMN_AGE = "age"; public MyDatabaseHelper(Context context) { super(context, DB_NAME, null, DB_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String sql = "CREATE TABLE " + TABLE_NAME + " (" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + COLUMN_NAME + " TEXT," + COLUMN_AGE + " INTEGER)"; db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { if (oldVersion < newVersion) { String sql = "DROP TABLE IF EXISTS " + TABLE_NAME; db.execSQL(sql); onCreate(db); } } } ``` 在上述代码中,我们定义了一个名为my_database的数据库,以及一个名为my_table的表,表中包含三个字段:_id、name和age。 接下来,我们可以在代码中调用MyDatabaseHelper类来创建数据库和表,以及进行操作。比如,我们可以在某个Activity的onCreate()方法中添加如下代码: ```java MyDatabaseHelper dbHelper = new MyDatabaseHelper(this); SQLiteDatabase db = dbHelper.getWritableDatabase(); // 插入操作 ContentValues values = new ContentValues(); values.put("name", "张三"); values.put("age", 20); db.insert("my_table", null, values); // 更新操作 ContentValues values = new ContentValues(); values.put("age", 21); db.update("my_table", values, "name=?", new String[]{"张三"}); // 除操作 db.delete("my_table", "name=?", new String[]{"张三"}); // 询操作 Cursor cursor = db.query("my_table", null, null, null, null, null, null); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex("_id")); String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); Log.d("MainActivity", "id=" + id + ", name=" + name + ", age=" + age); } cursor.close(); db.close(); ``` 在上述代码中,我们通过MyDatabaseHelper类获取了可写的数据库对象db,然后进行了插入、更新、除和询操作,最后关闭了数据库和游标。 接下来,我们来实现SharedPreferences存储数据。SharedPreferences是安卓提供的轻量级存储方式,可以用来存储一些简单的键值对数据。比如,我们可以在某个Activity中添加如下代码: ```java SharedPreferences sp = getSharedPreferences("my_prefs", Context.MODE_PRIVATE); SharedPreferences.Editor editor = sp.edit(); editor.putString("name", "张三"); editor.putInt("age", 20); editor.apply(); String name = sp.getString("name", ""); int age = sp.getInt("age", 0); Log.d("MainActivity", "name=" + name + ", age=" + age); ``` 在上述代码中,我们通过getSharedPreferences()方法获取了名为my_prefs的SharedPreferences对象,并使用了putString()和putInt()方法存储了数据。然后,我们又通过getString()和getInt()方法获取了存储的数据。 最后,我们来实现文件存储。安卓提供了多种文件存储方式,比如内部存储、外部存储和Assets等。这里我们以内部存储为例,来演示如何存储和读取文件。比如,我们可以在某个Activity中添加如下代码: ```java String fileName = "my_file.txt"; String content = "Hello, world!"; try { FileOutputStream fos = openFileOutput(fileName, Context.MODE_PRIVATE); fos.write(content.getBytes()); fos.close(); } catch (IOException e) { e.printStackTrace(); } try { FileInputStream fis = openFileInput(fileName); byte[] buffer = new byte[1024]; int length = fis.read(buffer); fis.close(); String result = new String(buffer, 0, length); Log.d("MainActivity", "result=" + result); } catch (IOException e) { e.printStackTrace(); } ``` 在上述代码中,我们使用了openFileOutput()方法创建了一个名为my_file.txt的文件,并将字符串"Hello, world!"写入该文件。然后,我们又使用了openFileInput()方法读取了该文件,并将读取的内容转换成字符串输出。 好了,以上就是实现SQLite数据库的创建、操作,实现SharedPreferences存储数据,实现文件存储的全部步骤了。希望能对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值