day07数据库

数据库

1.Android 系统中集成的轻量级的数据库
2.特点:
轻量级 只用一个动态的库, 是以单个文件的形式进行存取
跨平台 支持多个操作系统
零配置 无需安装, 直接使用
嵌入式 内嵌到手机中
3.在程序的内部可以通过数据库的名称访问, 其他应用不能访问
4.路径: data/data/应用程序包名/database/ ****.db
5.存放的类型:
NULL 空值
INTEGER 整型(不用int)
VARCHAR 可变长度的字符数据
TEXT 文本字符串
BOOLEAN 布尔
DATE
TIME

二.数据库核心类
1.SQLiteOpenHelper 数据库的帮助类, “用于数据库的创建和版本更新”
(1)定义一个类, 继承SQLiteOpenHelper
(2)重写构造方法 :提供数据库的基本信息 : 上下文对象,数据库名称,Null,数据库的版本号
(3)重写父类的方法:
onCreate():第一次创建数据库时调用, 只会执行一次 – “初始化表,初始化数据”
onUpgrade()
2.SQLiteDatabase 数据库的操作类, “操作数据库: 执行sql语句/增/删/改/查”
(0)获取SQLiteDatabase对象
(1)执行sql 语句
void execSQL(String sql,String[] bindArgs); 执行增删改
Cusor rawQuery(String sql,String[] selectionArgs); 执行查询
(2)执行方法 – 封装好的方法 (适用于菜鸟级别的程序员)
insert() 插入数据
update() 修改数据
delete() 删除数据

1.创建表:
create table student(_id integer primary key autoincrement,name varchar(30),age integer,address varchar(30));
2.添加数据:insert into student values(null,‘要甜雪’,18,‘北京市海淀区’);
3.修改数据:update student set age=13,address=‘河北省沧州市’ where name=‘要甜雪’;
4. 查询数据:
select * from student where 字段 = ‘值’
模糊查询: select * from 表名 where name like ‘%小%’
select * from student order by age desc 降序查询
sum(列名) 求和
max(列名) 最大值
min(列名) 最小值
avg(列名) 求平均值
count(列名) 统计记录数
5.删除数据:delete from student where id=12;


class MyHepler extends SQLiteOpenHelper {
    //参数一 上下文 参数二 数据库名称 参数三 工厂 null使用默认  参数四 版本号 1
    public MyHepler( Context context) {
        super(context, "1703.db", null, 1);
    }
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("create table student(id integer primary key autoincrement,name varchar(30),age integer )");
        db.execSQL("insert into student values(null,'你好',38),(null,'嘻嘻',18),(null,'飒飒',68)");
    }
    //TODO 更新数据库:不用写
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}
//查询
   //        //参数一 sql语句 参数二 为sql语句?赋值
//        Cursor cursor = database.rawQuery("select * from student where age>?", new String[]{"18"});
//        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.i("ytx", "query: "+id+":"+name+":"+age);
//        }

        /**
         * @param table  表名
         * @param columns  列数 String[]
         * @param selection 条件
         * @param selectionArgs 为条件中?赋值 String[]
         * @param groupBy  分组
         * @param having   分组之后筛选
         * @param orderBy  排序
         */

        //select name from student where age>18 order by age desc;
//        Cursor cursor = database.query("student", null, "age>?", new String[]{"18"}, null, null, "age desc");
        Cursor cursor = database.query("student", null, null,  null, null, null, "age desc");
        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.i("###", "query: "+id+":"+name+":"+age);
        }
//修改
 /**
         * @param table 表明
         * @param values  ContentValues
         * @param whereClause 条件
         * @param whereArgs 为条件?赋值
         * @return  受影响的条数
         */
        //update student set age=age+1 where age>18
        ContentValues contentValues = new ContentValues();
        contentValues.put("age","20");
        int num=database.update("student",contentValues,"age=?",new String[]{"18"});
        Toast.makeText(this, ""+num, Toast.LENGTH_SHORT).show();
//删除
  //参数一 表明  参数二 条件  参数三 为条件中的?赋值
        //String table, String whereClause, String[] whereArgs
        //delete from student where age=18;
        int num = database.delete("student", "age=?", new String[]{"38"});//返回值是成功删除了多少条
        Toast.makeText(this, "成功删除了"+num, Toast.LENGTH_SHORT).show();
//添加
/**
         * @param table 表名
         * @param nullColumnHack 如果没有赋值给默认值
         * @param values  ContentValues对象 存储你要插入的数据
         *   返回值 long 代表你插入的这一条是数据库中第几条
         */
        ContentValues contentValues = new ContentValues();
        contentValues.put("name","娃哈哈");
        contentValues.put("age","27");
        long num = database.insert("student", null, contentValues);
        if(num>0){
            Toast.makeText(this, "成功", Toast.LENGTH_SHORT).show();
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值