values: 要被修改成为的新值
whereClause:where子句,除去where关键字剩下的部分,其中可带?占位符。如没有子句,则为null。
whereArgs: 用于替代whereClause参数中?占位符的参数。如不需传入参数,则为null。
查询数据:query()方法用SELECT 语句段构建查询。SELECT 语句内容作为 query() 方法的参数,比如:要查询的表名,要获取的字段名,WHERE 条件,包含可选的位置参数,去替代 WHERE 条件中位置参数的值,GROUP BY 条件,HAVING 条件。
除了表名,其他参数可以是 null。所以,以前的代码段可以可写成:
String[] columns={“ID”,“inventory”};
String[] parms={“snicklefritz”};
Cursor result=db.query(“widgets”,columns, “name=?”,parms, null, null, null);
使用游标
不管你如何执行查询,都会返回一个 Cursor,这是 Android 的 SQLite 数据库游标,使用游标,你可以:
通过使用 getCount() 方法得到结果集中有多少记录;
通过 moveToFirst(), moveToNext(), 和 isAfterLast() 方法遍历所有记录;
通过 getColumnNames() 得到字段名;
通过 getColumnIndex() 转换成字段号;
通过 getString(),getInt() 等方法得到给定字段当前记录的值;
通过 requery() 方法重新执行查询得到游标;
通过 close() 方法释放游标资源;
删除数据:删除数据也是一件很简单的事,只需要调用delete方法,传入参数即可,delete(String table, String whereClause,String[] whereArgs)的参数三个参数具体含义如下:
table: 目标表名
whereClause:where子句,除去where关键字剩下的部分,其中可带?占位符。如没有子句,则为null。
whereArgs: 用于替代whereClause参数中?占位符的参数。如不需传入参数,则为null。
4、**contentprovider:**contentprovider四种基本概念
1、 ContentProvider提供为存储和获取数据提供了统一的接口;
2、 使用ContentProvider可以在不同的应用程序之间共享数据
3、 Android为常见的一些数据提供了ContentPrivider(包括音频,视频,图片和通讯录等等)
ContentProvider使用表的形式来组织数据
Uri
1、 每一个ContentProvider都拥有一个公共的uri,这个uri用于表示这个ContentProvider所提供的数据
2、 Android所提供的ContentProvider都存放在android.provider包当中
Uri代表了要操作的数据,Uri主要包含了两部分信息:1.需要操作的ContentProvider ,对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:
1.scheme:ContentProvider(内容提供者)的scheme已经由Android所规定为:content://。
2.主机名(或Authority):用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。
3.路径(path):可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下:
要操作contact表中id为10的记录,可以构建这样的路径:/contact/10
要操作contact表中id为10的记录的name字段, contact/10/name
要操作contact表中的所有记录,可以构建这样的路径:/contact
要操作的数据不一定来自数据库,也可以是文件等他存储方式,如下:
要操作xml文件中contact节点下的name节点,可以构建这样的路径:/contact/name
如果要把一个字符串转换成Uri,可以使用Uri类中的parse()方法,如下:
Uriuri =Uri.parse(“content://com.changcheng.provider.contactprovider/contact”)
ContentProvider所提供的函数:
1、 query():查询
2、 insert():插入
3、 update():更新
4、 delete():删除
5、 getType():得到数据类型
6、 onCreate():创建时的回调函数
实现ContentProvider的过程
1、 定义一个CONTENT_URI常量
2、 定义一个类,继承ContentProvider
3、 实现query,insert,update,delete,getType,onCreate方法
4、 在AndroidManifest.xml当中进行声明
下面是实现代码:
首先创建继承contentprovider的类UserContentProvider .java
-
public class UserContentProvider extends ContentProvider {
-
private DatabaseHelper helper;
-
private SQLiteDatabase db;
-
private static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);
-
private static final int USERS = 1;
-
private static final int USER = 2;
-
static{
-
matcher.addURI(“cn.csdn.activity.providers.userprovider”, “user”, USERS);
-
matcher.addURI(“cn.csdn.activity.providers.userprovider”, “user/#”, USER);
-
}
-
public int delete(Uri uri, String selection, String[]selectionArgs) {
-
db=helper.getWritableDatabase();
-
int num=0;
-
switch(matcher.match(uri)){
-
case USERS:
-
num=db.delete(“user”, selection, selectionArgs);
-
break;
-
case USER:
-
long id=ContentUris.parseId(uri);
-
String where=“id=”+id;
-
if(selection!=null&&!“”.equals(selection)){
-
where=where+" and"+selection;
-
}
-
num=db.delete(“user”, where, selectionArgs);
-
break;
-
default:
-
throw new IllegalArgumentException(“Unknown Uri:”+ uri);
-
}
-
return num;
-
}
-
public String getType(Uri uri) {
-
switch(matcher.match(uri)){
-
case USERS:
-
return “vnd.android.cursor.dir/person”;
-
case USER:
-
return “vnd.android.cursor.item/person”;
-
default:
-
throw new IllegalArgumentException(“Unknown Uri:”+ uri);
-
}
-
}
-
public Uri insert(Uri uri, ContentValues values) {
-
db=helper.getWritableDatabase();
-
long rowid;
-
switch(matcher.match(uri)){
-
case USERS: //向表中添加新纪录并返回其行号
-
rowid=db.insert(“user”, “id”, values);
-
return ContentUris.withAppendedId(uri, rowid);
-
default:
-
throw new IllegalArgumentException(“Unknow Uri:” + uri);
-
}
-
}
-
public boolean onCreate() {
-
helper=new DatabaseHelper(this.getContext(),“users.db”);
-
return true;
-
}
-
public Cursor query(Uri uri, String[] projection, Stringselection,
-
String[] selectionArgs, String sortOrder) {
-
db = helper.getReadableDatabase();
-
switch(matcher.match(uri)){
-
case USERS:
-
return db.query(“user”, projection, selection, selectionArgs, null, null, sortOrder);
-
case USER:
-
long id=ContentUris.parseId(uri);
-
String where=“id=”+id;
-
if(selection!=null&&!“”.equals(selection)){
-
where=where+" and"+selection;
-
}
-
return db.query(“user”, projection, where, selectionArgs, null, null, sortOrder);
-
default:
-
throw new IllegalArgumentException(“Unknown Uri:”+ uri);
-
}
-
}
-
public int update(Uri uri, ContentValues values, String selection,
-
String[] selectionArgs) {
-
db=helper.getWritableDatabase();
-
int num;
-
switch(matcher.match(uri)){
-
case USERS:
-
num=db.update(“user”, values, selection, selectionArgs);
-
break;
-
case USER:
-
long id=ContentUris.parseId(uri);
-
String where=“id=”+id;
-
if(selection!=null&&!“”.equals(selection)){
-
where=where+" and"+selection;
-
}
-
num=db.update(“user”, values, selection, selectionArgs);
-
break;
-
default:
-
throw new IllegalArgumentException(“Unknow Uri”+uri);
-
}
-
return num;
-
}
-
}
-
配置manifest.xml:
-
需要在中为provider进行注册!!!!
-
provider android:authorities=“cn.csdn.activity.providers.userprovider”
-
android:name=“UserContentProvider”>
-
最后写测试类:
-
//contentprovider测试
-
public void testinsert(){//插入数据
-
ContentResolver resolver = this.getContext().getContentResolver();
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
总结
最后为了帮助大家深刻理解Android相关知识点的原理以及面试相关知识,这里放上相关的我搜集整理的Android开发中高级必知必会核心笔记,共计2968页PDF、58w字,囊括Android开发648个知识点,我把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包知识脉络 + 诸多细节。
以上分享【Android开发中高级必知必会核心知识笔记】七大模块整套学习资料均免费分享,需要的小伙伴,我已经上传到GitHub了,大家自取就可以了。白嫖可以,别忘了给我点个关注哈。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
2021年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。
虽然面试失败了,但我也不会放弃入职字节跳动的决心的!建议大家面试之前都要有充分的准备,顺顺利利的拿到自己心仪的offer。
模块整套学习资料均免费分享,需要的小伙伴,我已经上传到GitHub了,大家自取就可以了。白嫖可以,别忘了给我点个关注哈。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
2021年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。
虽然面试失败了,但我也不会放弃入职字节跳动的决心的!建议大家面试之前都要有充分的准备,顺顺利利的拿到自己心仪的offer。