目录
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);
}
}