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; } } }
相关推荐
第二类平台服务提供者,如社交媒体或博客平台,他们提供的不仅是技术支持,还有平台供用户发布内容。这类服务提供者对于用户上传内容的侵权责任,各国法律规定不尽相同。在美国,根据《数字千年版权法》(DMCA),...
2005年的《互联网著作权行政保护办法》则是一部针对网络服务提供者的行政法规,规定了“通知-删除”程序,但主要针对技术服务提供者,未涵盖内容提供者。2006年的《信息网络传播权保护条例》则更全面地定义了网络...
文章首先从搜索引擎服务提供者在法律上的身份定位入手,指出其可以被视为网络服务提供者或网络内容提供者。这种身份的差别导致了其法律责任的不同。网络服务提供者通常受到“避风港原则”的保护,意味着当他们仅仅...
在法律层面,互联网医疗平台提供者可能同时承担着信息提供者、中介服务者以及技术平台经营者等多种角色。这导致在发生医疗纠纷时,确定平台的法律责任存在困难。明确互联网医疗平台提供者的法律地位,有助于确定其在...
云服务提供者通常对通过其服务传递的信息和内容没有实际控制能力,因此一概要求其断开服务,可能不符合“手段-目的”比例性原则。这种责任的灵活性,要求网络服务提供者在不同阶段应有不同的责任要求,如事前的必要...
随着《食品安全法》及相关法规的不断完善和严格实施,餐饮服务提供者不仅需要建立完善的食品安全管理制度,还需要定期进行自我检查以确保各项制度的有效执行。 ### 自查表的设计与实现 #### 1. **表格设计** - **...
《信息网络传播权保护条例》、《侵权责任法》以及《电子商务法》等法律法规中有关网络服务提供者的定义和适用范围,需要结合具体案例进行解读。在此基础上,法院需明确何种措施属于必要且合理的范围,何种情形下可以...
这两个案例展示了网络服务提供者如何在技术发展与法律监管之间寻找平衡,以及如何处理与用户、开发者和其他利益相关方的关系。 在“小程序”案中,可能讨论了平台对于用户生成内容的监管责任,包括是否需要对所有...
1. **通用要求**:该标准规定了能力测试提供者必须遵循的一般原则,包括管理、技术操作、公正性、保密性和透明度等方面的要求。 2. **管理体系**:强调能力测试提供者的管理体系应确保其活动的连续性和有效性,包括...
互联网时代音视频节目技术和内容的革新涉及了多个方面,其中技术和内容的融合是推动发展的核心。...以上内容综合考虑了互联网时代音视频节目技术与内容的革新要点,为行业内的从业者和研究者提供了宝贵的知识和参考。
7. **内容提供者(ContentProvider)**:当应用需要与其他应用共享数据时,内容提供者就显得尤为重要。本书将介绍如何使用内容提供者进行数据共享。 8. **数据存储技术**:应用往往会涉及数据的存储,本书将讲解包括...
使用场景及目标:帮助相关人员掌握CDN的工作流程及其为企业和消费者提供的实际利益,探索其未来发展潜力。 其他说明:除了基本概念和传统应用外,文章特别提到了CDN在现代互联网环境中遭遇的安全问题和发展趋势,如...
该资料出自哈佛大学肯尼迪学院的政策研究项目,旨在向政策制定者提供电池技术的概述及其相关政策考量。 其次,文件描述中提到“哈佛肯尼迪学院-政策制定者技术资料:电池技术(英文)-2021.2-16页.pdf”揭示了文档...
然而,我们可以从文件的标题和描述中提取有用信息,即该文档与华为HCNA网络技术认证有关,并提供相关知识点。 华为HCNA(Huawei Certified Network Associate)是华为公司推出的一项网络技术认证,面向那些希望通过...
从提供的部分内容来看,本次面试涉及的技术领域非常广泛,包括但不限于网络技术、操作系统、硬件维护等方面。以下是对这些知识点的详细总结: ### 网络技术相关知识点 - **网络设备与协议**:面试中提到了多种网络...