技术韭菜 2022-05-31 17:04 采纳率: 58.3%
浏览 38
已结题

SQLite数据库的创建

SQLiteDataBaseSQLiteOpenHelper的区别是什么?
实例化SQLiteDataBase和实例化SQLiteOpenHelper分别创建出来的对象是什么?

创建SQLite数据库的代码如下:

public class MyHelper extends SQLiteOpenHelper {

    public MyHelper(@Nullable Context context) {
        super(context, "directory_example.db", null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        sqLiteDatabase.execSQL("CREATE TABLE information(user_id INTEGER PRIMARY KEY AUTOINCREMENT,user_name VARCHAR(20),user_phone INTEGER)");
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

    }
}

其中下边的语句是不是用来创建数据库的?

    public MyHelper(@Nullable Context context) {
        super(context, "directory_example.db", null, 1);
    }

那么下边的语句是用来创建什么的?和上边的具有区别是什么?

    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        sqLiteDatabase.execSQL("CREATE TABLE information(user_id INTEGER PRIMARY KEY AUTOINCREMENT,user_name VARCHAR(20),user_phone INTEGER)");
    }
  • 写回答

2条回答 默认 最新

  • CSDN专家-sinJack 2022-05-31 17:13
    关注

    SQLiteDatabase 是用于执行数据库操作的类,SQLiteOpenHelper 是 SQLiteDatabase 的一个帮助类,用来管理数据库的创建和版本的更新。
    其中 SQLieDatase 对象是通过 SOLiteOpenHelper调用方法来获得的。
    SQLiteDatabase类一般用来操作表数据,如对数据表的数据进行增删改查操作。
    SQLiteOpenHelper 类一般用来操作表结构,如创建表、修改表结构等。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月15日
  • 已采纳回答 10月7日
  • 创建了问题 5月31日

悬赏问题

  • ¥60 优博讯DT50高通安卓11系统刷完机自动进去fastboot模式
  • ¥15 minist数字识别
  • ¥15 在安装gym库的pygame时遇到问题,不知道如何解决
  • ¥20 uniapp中的webview 使用的是本地的vue页面,在模拟器上显示无法打开
  • ¥15 网上下载的3DMAX模型,不显示贴图怎么办
  • ¥15 关于#stm32#的问题:寻找一块开发版,作为智能化割草机的控制模块和树莓派主板相连,要求:最低可控制 3 个电机(两个驱动电机,1 个割草电机),其次可以与树莓派主板相连电机照片如下:
  • ¥15 Mac(标签-IDE|关键词-File) idea
  • ¥15 潜在扩散模型的Unet特征提取
  • ¥15 iscsi服务无法访问,如何解决?
  • ¥15 感应式传感器制作的感应式讯响器