android中数据库一般是不能直接被其他程序创建的,一般是通过内容提供者 ,内容提供者是android开发中常见的数据操作方式,例如;android手机的联系人信息获取 我们是可以直接操作android提供的内容提供者的, android需要做的就是在联系人中定义一个内容提供者;
内容提供者关键步骤:
1,创建(A程序)数据库; 继承SQLiteOpenHelper创建数据库和表
2,创建(A程序)的内容提供者; 继承Contentprovider自定义内容提供者
3,创建(B程序)操作A程序的数据(增删该查) ; 使用上下文获取内容提供者
一: A程序;
1,定义A程序的数据库
package com.example.DemoDB; /** * 数据库的创建 */ import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; public class HelperDemo extends SQLiteOpenHelper{ public HelperDemo(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); // TODO Auto-generated constructor stub } @Override public void onCreate(SQLiteDatabase db) { //创建表 String sql="create table user(_id integer primary key autoincrement,userphone txet,username text)"; //使用execSQL只用sql语句 db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub } }
2,创建显示操作数据的xml文件
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/textView1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_marginTop="130dp" /> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_below="@+id/textView1" android:layout_marginLeft="18dp" android:layout_marginTop="44dp" android:onClick="optionuser" android:text="添加" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@+id/button1" android:layout_marginLeft="46dp" android:layout_toRightOf="@+id/button1" android:onClick="optionuser" android:text="删除" /> <Button android:id="@+id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignLeft="@+id/button1" android:layout_below="@+id/button1" android:layout_marginTop="22dp" android:onClick="optionuser" android:text="修改" /> <Button android:id="@+id/button4" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/button3" android:layout_alignBottom="@+id/button3" android:layout_alignLeft="@+id/button2" android:onClick="optionuser" android:text="查询" /> </RelativeLayout>
3,创建A程序的数据库和操作数据库方法,将操作的结果显示出来
package com.example.DemoDB; import com.example.sharedpreferrences.R; import android.app.Activity; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.TextView; import android.widget.Toast; /** * * @author Administrator 数据库的操作 */ public class DemoDB extends Activity { private TextView v1; private Button t1; private Button t2; private Button t3; private Button t4; private HelperDemo demo; private SQLiteDatabase database; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_db); //创建数据库 user_contacts数据库的名字 demo = new HelperDemo(this, "user_contacts", null, 1); //增删改查按钮和显示数据按钮 v1 = (TextView) this.findViewById(R.id.textView1); t1 = (Button) this.findViewById(R.id.button1); t2 = (Button) this.findViewById(R.id.button2); t3 = (Button) this.findViewById(R.id.button3); t4 = (Button) this.findViewById(R.id.button4); } // 数据库的操作 public void optionuser(View v) { switch (v.getId()) { case R.id.button1:// 添加数据 database = demo.getWritableDatabase(); if (database == null) { Toast.makeText(this, "不能添加数据", Toast.LENGTH_SHORT).show(); } else { // 第一个方式 String sql = "insert into user values(null,'12345','长沙')"; database.execSQL(sql); // 第二种方式 // 参数一:表名 // 参数二:null // 参数三:使用ContentValues赋值 // ContentValues values = new ContentValues(); // values.put("userphone", "123"); // values.put("username", "value"); // // database.insert("user", null, values); selectuser(); } break; case R.id.button2:// 删除 database = demo.getWritableDatabase(); if (database == null) { Toast.makeText(this, "不能删除数据数据", Toast.LENGTH_SHORT).show(); } else { // //第一种方式 // String sql ="delete from user where _id=?"; // String[] str= {"1"}; // database.execSQL(sql, str); // 第二种方式 // 参数一:表名 // 参数二:条件 // 参数三:条件的值 String whereClause = "_id=?"; String[] whereArgs = { "2" }; database.delete("user", whereClause, whereArgs); } selectuser(); break; case R.id.button3:// 修改 database = demo.getWritableDatabase(); if (database == null) { Toast.makeText(this, "不能修改数据", Toast.LENGTH_SHORT).show(); } else { // 第一种方式 // String sql="update user set username='武汉' where _id=6"; // database.execSQL(sql); // 参数一:表名 // 参数二:更新的值 // 参数三:?的字段名 // 参数四:?字段名的值 ContentValues values = new ContentValues(); values.put("username", "北京"); String whereClause = "_id=?"; String[] whereArgs = { "5" }; database.update("user", values, whereClause, whereArgs); } selectuser(); break; case R.id.button4:// 查询 selectuser(); break; } } // 查询 public void selectuser() { SQLiteDatabase database2 = demo.getReadableDatabase(); // // 第一种方式 // String sql = "select * from user order by _id desc"; // Cursor c = database2.rawQuery(sql, null); // StringBuffer buffer = new StringBuffer(); // while (c.moveToNext()) { // int id = c.getInt(c.getColumnIndex("_id")); // String phone = c.getString(c.getColumnIndex("userphone")); // String name = c.getString(c.getColumnIndex("username")); // buffer.append(id + "\t姓名:\t" + name + "<><>电话:\t" + phone + "\r\n"); // } // v1.setText(buffer); //第二种方式 //参数一:表名 //查询数据会返回一个游标对象,遍历游标对象就得到值 Cursor c=database2.query("user", null, null, null, null, null, null); StringBuffer buffer = new StringBuffer(); while (c.moveToNext()) { int id = c.getInt(c.getColumnIndex("_id")); String phone = c.getString(c.getColumnIndex("userphone")); String name = c.getString(c.getColumnIndex("username")); buffer.append(id + "\t姓名:\t" + name + "<><>电话:\t" + phone + "\r\n"); } v1.setText(buffer); } }
4,定义A程序的内容提供者
package com.example.DemoDB; /** * 内容提供者 */ import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues; import android.content.UriMatcher; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.net.Uri; /** * * @author Administrator 使用内容提供者共享数据 第一步:继承ContentProvider 第二步; <provider * android:name="com.example.DemoDB.MyContent" * android:authorities="com.example.DemoDB.MyContent.provider" * android:exported="true"></provider> */ public class MyContent extends ContentProvider { // 定义字符串用来匹配的关键 static String authority = "com.MyContent.provider"; // 定义一个URI匹配器,NO_MATCH表示默认不匹配任何路径 static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH); // 使用静态块来添加可匹配路径,为了保证在执行那个程序之前,匹配器中有可匹配路径 static { // 参数一:内容提供者 // 参数二:名字 // 参数三:匹配的地址 matcher.addURI(authority, "insretdate", 1);//插入 matcher.addURI(authority, "selectdate", 2);//查询 matcher.addURI(authority, "daletedate", 3);//删除 matcher.addURI(authority, "updatedate", 4);//修改 } private HelperDemo demo; @Override public boolean onCreate() { // 创建数据库 demo = new HelperDemo(this.getContext(), "user_contacts", null, 1); return true; } @Override public String getType(Uri uri) { // 获得类型 return null; } @Override public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { // 匹配内容提供者的数据 int code = matcher.match(uri); if (code != 2) { throw new IllegalArgumentException("参数异常:" + uri); } //判断是否可读 SQLiteDatabase querydatabase=demo.getReadableDatabase(); if(querydatabase==null){ throw new RuntimeException("数据不存在"); } Cursor cursor=querydatabase.query("user", projection, selection, selectionArgs, null, null, sortOrder); return cursor; } @Override // 插入数据 public Uri insert(Uri uri, ContentValues values) { // 匹配uri int code = matcher.match(uri); if (code != 1) { throw new IllegalArgumentException("插入数据时参数异常:" + uri); } SQLiteDatabase db = demo.getWritableDatabase(); if (db == null) { throw new RuntimeException("无法插入数据,数据库对象为只读!"); } // 返回的是插入的数据的id 插入到数据库可以使用insertOrThrow 和insert插入 long id = db.insertOrThrow("user", "_id", values); // 返回的Uri代表被插入的数据 uri = ContentUris.withAppendedId(uri, id); return uri; } @Override // 删除数据 public int delete(Uri uri, String selection, String[] selectionArgs) { //匹配编码 int code=matcher.match(uri); if(code!=3){ throw new IllegalArgumentException("删除参数异常:"+uri); } //判断是否可写 SQLiteDatabase sd= demo.getWritableDatabase(); if(sd==null){ throw new RuntimeException("删除 运行时异常"); } //删除数据 int len=sd.delete("user", selection, selectionArgs); return len; } @Override // 更新数据 public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { int code=matcher.match(uri); if(code!=4){ throw new IllegalArgumentException("更新参数异常:"+uri); } SQLiteDatabase sd=demo.getWritableDatabase(); if(sd==null){ throw new RuntimeException("更新运行时异常"); } //更新数据 int len=sd.update("user", values, selection, selectionArgs); return len; } }
分析:
a, MyContent类执行时,先初始化static的相关属性,
// 定义字符串用来匹配的关键 static String authority = "com.MyContent.provider"; // 定义一个URI匹配器,NO_MATCH表示默认不匹配任何路径 static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH); // 使用静态块来添加可匹配路径,为了保证在执行那个程序之前,匹配器中有可匹配路径 static { // 参数一:内容提供者 // 参数二:名字 // 参数三:匹配的地址 matcher.addURI(authority, "insretdate", 1);//插入 matcher.addURI(authority, "selectdate", 2);//查询 matcher.addURI(authority, "daletedate", 3);//删除 matcher.addURI(authority, "updatedate", 4);//修改 }
b, B程序操作A程序的内容提供者是通过 addURI()方法中的名字 找到内容提供者,通过匹配地址找到插 入语句
5,清单中注册
<provider
android:name="com.example.DemoDB.MyContent"
android:authorities="com.MyContent.provider"
android:exported="true"></provider>
</application>
二 :B程序
操作A程序中的内容提供者的步骤:
上下文获取内容提供者
1,xml文件 按不同的按钮输入框输入的结果不同,请仔细查看B程序中按钮的操作
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello_world" /> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_alignParentLeft="true" android:layout_marginBottom="141dp" android:onClick="show" android:text="更新" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/button1" android:layout_alignBottom="@+id/button1" android:layout_toRightOf="@+id/textView1" android:onClick="show" android:text="查询" /> <Button android:id="@+id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignRight="@+id/button1" android:layout_below="@+id/button2" android:layout_marginTop="36dp" android:onClick="show" android:text="删除" /> <Button android:id="@+id/button4" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/button3" android:layout_alignBottom="@+id/button3" android:layout_alignRight="@+id/editText2" android:onClick="show" android:text="添加" /> <EditText android:id="@+id/editText2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignLeft="@+id/button1" android:layout_centerVertical="true" android:ems="10" /> <EditText android:id="@+id/editText1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_above="@+id/editText2" android:layout_alignLeft="@+id/editText2" android:layout_marginBottom="14dp" android:ems="10" > <requestFocus /> </EditText> </RelativeLayout>
2,B程序操作A程序的内容提供者
package com.example.date.provider; import android.net.Uri; import android.os.Bundle; import android.app.Activity; import android.content.ContentResolver; import android.content.ContentValues; import android.database.Cursor; import android.view.Menu; import android.view.View; import android.widget.EditText; import android.widget.TextView; /** * * @author Administrator *操作数据保存程序的内容提供者,实现增删改查操作 */ public class MainActivity extends Activity { private EditText editText1; private EditText editText2; private ContentResolver resolver; private TextView t1; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); t1=(TextView)this.findViewById(R.id.textView1); editText1 = (EditText) this.findViewById(R.id.editText1); editText2 = (EditText) this.findViewById(R.id.editText2); //获得内容提供者 resolver= this.getContentResolver(); } //实现按钮的监听器方法 public void show(View v) { switch (v.getId()) { case R.id.button1://更新数据 //获取输入框的值 String str=editText1.getText().toString().trim(); //内容提供者的地址 Uri uri= Uri.parse("content://com.MyContent.provider/updatedate"); ContentValues values= new ContentValues(); values.put("username", "天津"); String where="_id=?"; String[] selectionArgs={str}; //更新语句 resolver.update(uri, values, where, selectionArgs); break; case R.id.button2: //查询 Uri uriselect= Uri.parse("content://com.MyContent.provider/selectdate"); Cursor c= resolver.query(uriselect, null, null, null, null); StringBuffer buffer = new StringBuffer(); while (c.moveToNext()) { int id = c.getInt(c.getColumnIndex("_id")); String phone = c.getString(c.getColumnIndex("userphone")); String name = c.getString(c.getColumnIndex("username")); buffer.append(id + "\t姓名:\t" + name + "<><>电话:\t" + phone + "\r\n"); } t1.setText(buffer); break; case R.id.button3: //删除 Uri uridelete=Uri.parse("content://com.MyContent.provider/daletedate"); String str1=editText1.getText().toString().trim(); String wheredelete = "username=?"; String[] selectionArgsdelete = {str1}; resolver.delete(uridelete, wheredelete, selectionArgsdelete); break; case R.id.button4: //增加 Uri uriinsret= Uri.parse("content://com.MyContent.provider/insretdate"); //获取输入框中的姓名和电话 String name=editText1.getText().toString().trim(); String phone=editText2.getText().toString().trim(); //使用键值对存放数据 ContentValues valuesinsert = new ContentValues(); valuesinsert.put("username", name); valuesinsert.put("userphone", phone); //插入语句 resolver.insert(uriinsret, valuesinsert); break; } } }
相关推荐
我的内容面向数据科学家、机器学习工程师、自动驾驶研究人员和技术爱好者。无论你是刚入行的新手,还是在这一领域寻求更深刻理解的资深专家,这里都有适合你的内容。 通过阅读我的博客文章,你将能够: 掌握自动...
随后,详尽地对核心层网络封包截获技术的实现原理作了讲述,在讲述原理时主要介绍了一下几个方面的内容:分层服务提供者(LSP)的相关概念、原理和用途;核心层网络驱动和NDIS网络驱动程序;核心层网络封包截获技术的...
面试准备和技巧:提供面试准备的相关指导和技巧,如面试常见问题、解题思路、沟通表达技巧等。 通过参与这门课程,学习者将能够系统地学习和巩固Java技术知识,并在面试中展现自己的技术能力和优势。
这是由开源社区门户PHPChina与网上一些PHP技术爱好者共同制作的电子刊物,据杂志主创人员介绍,从酝酿思路到创刊号发行,总共花了两个多月,杂志的内容完全由网上的PHPer们积极提供。在发行致辞中,《PHPer》创作...
非扫描版的《自动化测试技术领航》 精通QTP:自动化测试技术领航 ... 《精通QTP:自动化测试技术领航》适合初学者、测试工程师、QTP项目开发人员、QTP架构师、测试经理、培训师等,也适合学校相关专业的教学用书。
本书全面介绍了移动多媒体消息业务的技术知识,内容涵盖了移动通信网络的基本原理和系统构成,多媒体信息编码和信息压缩的基本原理和方法,移动多媒体应用的相关协议,短消息业务的特点和业务流程,移动多媒体消息业务的...
《精通QTP:自动化测试技术领航》共分为6章,书中实例新颖、趣味性强、... 《精通QTP:自动化测试技术领航》适合初学者、测试工程师、QTP项目开发人员、QTP架构师、测试经理、培训师等,也适合学校相关专业的教学用书。
系统学习:建议学习者按照资源提供的顺序和内容,系统地学习和掌握Java的知识点。 实践为王:理论知识和实战经验相结合,通过实践来加深理解和记忆。 持续更新:由于Java技术和面试要求都在不断更新,建议学习者保持...
本书内容丰富,注重知识的先进性,体系合理,叙述脉络清楚,通俗易懂,可作为计算机专业和计算机相关专业的计算机入门教材或参考书,也可作为计算机爱好者的入门参考书。 目录前言 第1章计算机科学技术的基础知识 ...
一个实验性的 Android 项目,用于定位服务、地理围栏、地图、sqlite、内容提供者和后端服务器集成。 相关项目: : ##技术雇用 ContentProvider:访问位置和地理围栏信息 SQLite:持久化位置和地理围栏 Location...
(填写要求:根据国家相关法律法规及政策要求,结合算法推荐服务提供者实际情况,制定完备的算法安全管理制度,相关制度应作为约束算法推荐服务提供者自身行为、规范算法研发和管理工作流程的重要依据。制度文件应...
前言 感谢整理者 一、商圈和地区进行关联 4 二、其他页面显示购买记录的函数 5 三、多货币解决方案 6 四、仿淘宝商品详细页实现尺码颜色关联显示库存 12 五、仿淘宝商品详细页加入购物车效果 14 六、ecshop加入...
在这儿提及的本体论的框架,作为一项复杂的并且与不同的学习内容有关的相关作用,来表明我们如何使用语义诠释的相互联系来处理不同的学习情况。此外在这个框架内,作者为教育者改善未来基于web的课程的授课提供了几...
本书内容力求较系统地介绍电子银行安全的基本原理及所采用的主要技术!全书内容 共分1章!第+章和第(章是本书的出发点和纲"主要介绍电子银行的运行环境和安全需 求"包括电子银行的发展#电子银行体系和网络结构"并从...
本书是教育部世界银行贷款... 本书即可作为高等院校计算机及相关专业C++后续课程的教材或主要参考书,也可做为继续教育或网络培训中的程序设计课程教材,同时适用于有关工程技术人员和计算机爱好者学习参考。
本书是计算机通信国家级教学团队成果和北京市精品教材立项项目。, 全书以8086处理器和16位微型计算机系统为实例进行..., 本书适合作为高等学校理工科各专业微机原理与接口技术教材,也是相关技术人员或爱好者的参考书。
文章分析了人工 智能作用于计算机网络技术的特点优势与计算机网络技术的应用发展现状,并提出了人 工智能应用于计算机网络技术的策略方法,其目的是为相关建设者提供一些理论依据。 关键词:计算机网络技术;人工智能...
这份资源包内容丰富,涵盖了从基础知识到实战应用的全方位内容,旨在为开发者们提供一个便捷、高效的学习平台。 一、文件手册 资源包中的文件手册部分,详细记录了Android开发的核心知识点和常用技术。无论是初学...
阅读本书需要有关计算机技术的基础知识,稍懂计算机连网的计算机专家会发现他们有 足够的知识来理解本书的绝大多数内容,具备一些二进制代数方面的知识也会很有帮助,这 是计算机认识和计算数字的基本方法。 本书还...