Android的SQLite和BrodCast Receiver

目录

1.SQLite

SQLite操作数据库的步骤

        1. 创建数据库

        2. 在DBHelper建表和添加数据:

        3.代码实现

     在MainActivity里面执行增删改查操作

2.BrodCast Receiver

   1.介绍

   2.特性

   3.广播分类

   4.代码实现

最后做了一个小的案例


1.SQLite

MySQL特点:体积大、功能比较强

SQLite特点:存储小型数据,无需配置,本地化

SQLite操作数据库的步骤

          1. 创建数据库

    1.先创建一个java文件DBHelper

    2.继承SQLiteOpenHelper

    3.继承的抽象类SQLiteOpenHelper中的两个抽象方法

                onCreate()和onUpgrade

    4.创建一个有参的构造方法,在这里面里创建数据库

                有参的构造方法的四个参数的意思:

                    参数一:上下文   参数二:数据库的名称      参数三:工厂模式      参数四:版本

      2. 在DBHelper建表和添加数据:

需要在onCreate里建立

参数.execSQL(sql语句,建表的语句)

参数.execSQL(sql语句,添加数据的语句)

        3.代码实现

public class DBHelper extends SQLiteOpenHelper {


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


    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        //创建表
        sqLiteDatabase.execSQL("create table userinfo(id integer primary key,user text,pwd text)");
        //插入值
        sqLiteDatabase.execSQL("insert into userinfo values(1,'root','123456')");
        //SQLite特有方法
        ContentValues cv=new ContentValues();
        cv.put("id",2);
        cv.put("user","abc");
        cv.put("pwd","000000");
        sqLiteDatabase.insert("userinfo",null,cv);
    }

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

    }
}

     在MainActivity里面执行增删改查操作

1.查询

public class MainActivity3 extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main3);


        DBHelper dbHelper=new DBHelper(MainActivity3.this);
        dbHelper.getWritableDatabase();

        //获取数据对象
        SQLiteDatabase sqLiteDatabase=dbHelper.getWritableDatabase();
        //执行并查询SQL语句
        String sql="select * from userinfo";
        //使用游标卡尺来
        Cursor cursor=sqLiteDatabase.rawQuery(sql,null);
        //取出结果
        //使用集合Map取结果
        List<Map<String,Object[]>> liat=new ArrayList<>();
        while (cursor.moveToNext()){
            Map map=new HashMap();
            map.put("id",0);
            map.put("user",1);
            map.put("pwd",2);

            liat.add(map);
        }
        //释放资源
        dbHelper.close();
        cursor.close();

    }
}

查询中取出结果有三种方法,上方只是一种

        剩余两种方法

1.

        //普通的方法取结果
//        int i=0;
//        List<Object[]> list=new ArrayList<>();
//        while (cursor.moveToNext()){
//            int id= cursor.getInt(0);
//            String user=cursor.getString(1);
//            String pwd=cursor.getString(2);
//            i++;
//        }

2.

        //使用实体类取结果
//        List<Userinfo> list=new ArrayList<>();
//        while (cursor.moveToNext()){
//            Userinfo userinfo=new Userinfo();
//            userinfo.setId(cursor.getInt(0));
//            userinfo.setUser(cursor.getString(1));
//            userinfo.setPwd(cursor.getString(2));
//
//            list.add(userinfo);
//        }

        实体类代码就不展示了

public class MainActivity4 extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main4);

        DBHelper dbHelper=new DBHelper(MainActivity4.this);

        SQLiteDatabase sqLiteDatabase=dbHelper.getWritableDatabase();

        String sql="insert into userinfo values(?,?,?)";
        sqLiteDatabase.execSQL(sql,new String[]{String.valueOf(3),"ooo","456789"});

        dbHelper.close();
        sqLiteDatabase.close();
    }
}

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main5);

    DBHelper ab=new DBHelper(MainActivity5.this);

    SQLiteDatabase sqLiteDatabase=ab.getWritableDatabase();

    String sql="delete from userinfo where id=?";
    sqLiteDatabase.execSQL(sql,new String[]{"1"});

    ab.close();
    sqLiteDatabase.close();
}

2.BrodCast Receiver

1.介绍

      四大组件之一,必须在清单(androidManifest.xml)文件中进行注册

      是在组件之间传播数据(Intent)的一种机制

   2.特性

         广播接收者中不要做一些耗时的工作,否则会弹出Application No Response错误对话框(ANR)

        耗时的代码未执行结束时, 界面会卡住, 用户对界面进行了操作, 10秒之后耗时代码如果还未结束, 就会出现ANR异常

      怎样避免ANR?

                主线程中不要执行耗时的代码
                如果一定要做耗时的事情, 开启新线程, 在新线程中执行

  3.广播分类

                广播接收器主要分为两种类型:标准广播 和 有序广播

                   而标准广播有分为两种

                        动态注册和静态注册

                        动态注册是在Java代码中注册的

                        而静态注册是在androidManifest.xml中注册的

    4.代码实现

              静态代码实现

                  1.先创建一个BroadcastReceiver

                                

          2.创建广播接收者                  

package com.hopu.day8;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;

public class MyReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Log.i("MyReceiver","静态接受者接收的值:"+intent.getStringExtra("info"));
    }

             3.在androidManifest.xml中注册 

<receiver
    android:name=".MyReceiver"
    android:enabled="true"
    android:exported="true">
    <intent-filter>
        <action android:name="houpu" />
    </intent-filter>
</receiver>

              4.创建一个服务器在服务器中连接广播接收者并发送消息

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    but_static=findViewById(R.id.but_static);
    but_static.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Intent intent=new Intent();
            intent.setPackage(getPackageName());
            intent.setAction("houpu");
            intent.putExtra("info","你好");
            sendBroadcast(intent);
        }
    });

动态代码实现

            动态的所有步骤都是在服务器里面创建的

//连接广播接收者并发送消息

 but_dong=findViewById(R.id.but_dong);
    but_dong.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Intent intent=new Intent();
            intent.setAction("hopu1");
            intent.putExtra("info","动态的你好");
            sendBroadcast(intent);
        }
    });
        //注册
    dongtai=new dongtai();
    IntentFilter intentFilter=new IntentFilter();
    intentFilter.addAction("hopu1");
    registerReceiver(dongtai,intentFilter);
} 
//创建动态广播接收者 
class dongtai extends BroadcastReceiver{
        @Override
        public void onReceive(Context context, Intent intent) {
            Log.i("dongtai","动态接受者:"+intent.getStringExtra("info"));
        }
    }

//反注册
    @Override
    protected void onDestroy() {
        super.onDestroy();
        unregisterReceiver(dongtai);
    }
}

最后做了一个小的案例

        

import androidx.appcompat.app.AppCompatActivity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.os.Bundle;
import android.widget.Toast;

public class MainActivity3 extends AppCompatActivity {
    protected dongtai dongtai;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main3);

        //注册
        dongtai =new dongtai();
        IntentFilter intentFilter=new IntentFilter();
        intentFilter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
        registerReceiver(dongtai,intentFilter);
    }
    //
    class dongtai extends BroadcastReceiver{

        @Override
        public void onReceive(Context context, Intent intent) {
            ConnectivityManager connectivityManager=(ConnectivityManager) context.getSystemService(context.CONNECTIVITY_SERVICE);
            NetworkInfo networkInfo = connectivityManager.getActiveNetworkInfo();
            if (networkInfo!=null&&networkInfo.isAvailable()){
                if (networkInfo.getType()==ConnectivityManager.TYPE_WIFI){
                    Toast.makeText(context,"wifi",Toast.LENGTH_SHORT).show();
                }else if (networkInfo.getType()==ConnectivityManager.TYPE_MOBILE){
                    Toast.makeText(context,"流量",Toast.LENGTH_SHORT).show();
                }
            }else {
                Toast.makeText(context,"网络连接失败",Toast.LENGTH_SHORT).show();
            }
        }
    }
    //反注册
    @Override
    protected void onDestroy() {
        super.onDestroy();
        unregisterReceiver(dongtai);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值