android 怎么连接数据库

android 怎么连接数据库,第1张

在android中,为某个应用程序创建的数据库,只有它可以访问,其它应用程序是不能访问的,数据库位于Android设备/data/data/package_name/databases文件夹中。

1、想要将数据库文件导出可以使用eclipse,如图所示:

2、查看数据库,使用SQlite Database Browser,如图所示:

android读取数据库可以使用sqlite一些api进行读取,实例如下:

  / 

      查找一条数据 

      @param uid 

     /  

    public User find(Integer uid){  

        SQLiteDatabase db=dbOpenHelpergetReadableDatabase();  //创建数据库辅助类

        Cursor cursor =dbrawQuery("select  from user where uid=", new String[]{uidtoString()});  //创建一个游标

        if(cursormoveToFirst()){  //循环遍历查找数组

            int uid2=cursorgetInt(cursorgetColumnIndex("uid"));  

            String uname=cursorgetString(cursorgetColumnIndex("uname"));  

            String uaddress=cursorgetString(cursorgetColumnIndex("uaddress"));  

            User user=new User();  

            usersetUid(uid2);  

            usersetUname(uname);  

            usersetUaddress(uaddress);  

            return user;  

        }  

        cursorclose();  

        return null;  

    }

Android 不自动提供数据库。在 Android 应用程序中使用 SQLite,必须自己创建数据库,然后创建表、索引,填充数据。Android 提供了 SQLiteOpenHelper 帮助你创建一个数据库,你只要继承 SQLiteOpenHelper 类,就可以轻松的创建数据库。SQLiteOpenHelper 类根据开发应用程序的需要,封装了创建和更新数据库使用的逻辑。SQLiteOpenHelper 的子类,至少需要实现三个方法:

构造函数,调用父类 SQLiteOpenHelper 的构造函数

onCreate()方法;// TODO 创建数据库后,对数据库的 *** 作

onUpgrage()方法。// TODO 更改数据库版本的 *** 作

当你完成了对数据库的 *** 作(例如你的 Activity 已经关闭),需要调用 SQLiteDatabase 的 Close() 方法来释放掉数据库连接。

*** 作数据库的最佳实践是创建一个辅助类,例如联系人模块

class ContactsDatabaseHelper extends SQLiteOpenHelper

32 Cursor类

Android使用Cursor类返回一个需要的值,Cursor作为一个指针从数据库查询返回结果集,使用Cursor允许Android更有效地管理它们需要的行和列,你使用ContentValues对象存储键/值对,它的put()方法允许你插入不同数据类型的键值。

33 数据类型

SQLite 和其他数据库最大的不同就是对数据类型的支持,创建一个表时,可以在 CREATE TABLE 语句中指定某列的数据类型,但是你可以把任何数据类型放入任何列中。当某个值插入数据库时,SQLite 将检查它的类型。如果该类型与关联的列不匹配,则 SQLite 会尝试将该值转换成该列的类型。如果不能转换,则该值将作为其本身具有的类型存储。比如可以把一个字符串(String)放入 INTEGER 列。SQLite 称这为“弱类型”(manifest typing)。

四、数据库 *** 作

41创建和打开数据库

在Android中创建和打开一个数据库都可以使用openOrCreateDatabase方法来实现,因为它会自动去检测是否存在这个数据库,如果存在则打开,如果不存在则创建一个数据库:创建成功则返回一个SQLiteDatebase对象,否则抛出异常FileNotFoundException。

下面我们来创建一个名为Test的数据库,并返回一个SQLiteDatabase对象mSQLiteDatabase。

mSQLiteDatabase=thisopenOrCreateDatabase("Test",MODE_PRIVATE,null);

42创建表

通过execSQL方法来执行一条SQL语句。

String CREATE_TABLE="create table 表名(列名,列名,……)";

mSQLiteDatabaseexecSQL(CREATE_TABLE);

创建表的时候总要确定一个主键,这个字段是64位整型,别名_rowid。其特点就是自增长功能。当到达最大值时,会搜索该字段未使用的值(某些记录被删除_rowid会被回收),所以要唯一严格增长的自动主键必须加入关键字autoincrement。

43删除表

mSQLiteDatabase("drop table 表名");

您好,很高兴为您解答。

一、 联系人数据库

 联系人的数据库文件的位置

/data/data/comandroidproviderscontacts/databasescontacts2db

 数据库中重要的几张表

1、contacts表

该表保存了所有的手机测联系人,每个联系人占一行,该表保存了联系人的

ContactID、联系次数、最后一次联系的时间、是否含有号码、是否被添加

到收藏夹等信息。

2、raw_contacts表

该表保存了所有创建过的手机测联系人,每个联系人占一行,表里有一列标

识该联系人是否被删除,该表保存了两个ID:RawContactID和ContactID,

从而将contacts表和raw_contacts表联系起来。该表保存了联系人的

RawContactID、ContactID、联系次数、最后一次联系的时间、是否被添

加到收藏夹、显示的名字、用于排序的汉语拼音等信息。

3、 mimetypes

该表定义了所有的MimeTypeID,即联系人的各个字段的唯一标志。

4、data表

 该表保存了所有创建过的手机测联系人的所有信息,每个字段占一行 ,该表

保存了两个ID:MimeTypeID和RawContactID,从而将data表和

raw_contacts表联系起来。

 联系人的所有信息保存在列data1至data15中,各列中保存的内容根据

MimeTypeID的不同而不同。如保存号码(MimeTypeID=5)的那行数据中,

data1列保存号码,data2列保存号码类型(手机号码/家庭号码/工作号码等)。

二、对联系人的基本 *** 作

 这里的基本 *** 作只是针对手机测的联系人,(U)SIM侧的联系人的 ***

作后续介绍。

 如果对联系人的基本 *** 作,我们必须得到许可。

方法就是在AndroidManifestxml文件中配置如下权限:

<uses-permission android:name="androidpermissionREAD_CONTACTS" 

/>

<uses-permission android:name="androidpermissionWRITE_CONTACTS" 

/>

读取联系人

分为以下步骤:

1、先读取contacts表,获取ContactsID;

2、再在raw_contacts表中根据ContactsID获取RawContactsID;

3、然后就可以在data表中根据RawContactsID获取该联系人的各数据了。

// 获取用来 *** 作数据的类的对象,对联系人的基本 *** 作都是使用这个对象  

ContentResolver cr = getContentResolver();  

// 查询contacts表的所有记录  

Cursor cur = crquery(ContactsContractContactsCONTENT_URI, null, null,   

null, null);  

// 如果记录不为空  

if (curgetCount() > 0)  

{  

// 游标初始指向查询结果的第一条记录的上方,执行moveToNext函数会判断  

// 下一条记录是否存在,如果存在,指向下一条记录。否则,返回false。  

while (curmoveToNext())  

{  

    String rawContactsId = "";  

    String id =   

        curgetString(curgetColumnIndex(ContactsContractContacts_ID));  

    str += "ID:" + id + "\n";二、对联系人的基本 *** 作(4)  

    // 读取rawContactsId  

    Cursor rawContactsIdCur = crquery(RawContactsCONTENT_URI,   

        null,  

        RawContactsCONTACT_ID +" = ",    

        new String[]{id}, null);  

    // 该查询结果一般只返回一条记录,所以我们直接让游标指向第一条记录  

    if (rawContactsIdCurmoveToFirst())  

    {  

    // 读取第一条记录的RawContacts_ID列的值  

    rawContactsId =   

        rawContactsIdCurgetString(rawContactsIdCurgetColumnIndex(  

        RawContacts_ID));  

    }  

    rawContactsIdCurclose();// 读取号码  

If (IntegerparseInt(curgetString(curgetColumnIndex(ContactsContract  

    ContactsHAS_PHONE_NUMBER))) > 0)  

{  

// 根据查询RAW_CONTACT_ID查询该联系人的号码  

Cursor PhoneCur =   

    crquery(ContactsContractCommonDataKindsPhoneCONTENT_URI,  

    null,  

    ContactsContractCommonDataKindsPhoneRAW_CONTACT_ID +" =   

    ",  

    new String[]{rawContactsId}, null);  

// 上面的ContactsContractCommonDataKindsPhoneCONTENT_URI  

// 可以用下面的phoneUri代替  

//  Uri phoneUri=Uriparse("content://comandroidcontacts/data/phones");二、对联系人的基本 *** 作(6)  

// 一个联系人可能有多个号码,需要遍历  

while (PhoneCurmoveToNext())  

{  

// 号获取码  

String number =   

    PhoneCurgetString(PhoneCurgetColumnIndex(  

    ContactsContractCommonDataKindsPhoneNUMBER));  

// 获取号码类型  

String numberType =   

PhoneCurgetString(PhoneCurgetColumnIndex(  

    ContactsContractCommonDataKindsPhoneTYPE));  

}  

PhoneCurclose();

新建联系人

新建联系人时, 根据contacts、raw_ contacts两张表中ID的使用情况,自动

生成ContactID和RawContactID。

Android源码新建重复姓名的联系人的ContactID是不重复的,所以会重复显

示。

用下面的代码新建联系人,如果多次新建的联系人的姓名是一样的,生成的

ContactID也会重复,RawContactID不会重复,我们在读取联系人的时候可

以获取所有同姓名联系人的号码等信息,在显示联系人的时候,重复姓名的

联系人的所有字段信息都会合并起来显示为一个联系人。

ContentValues values = new ContentValues();  

Uri rawContactUri =   

getContentResolver()insert(RawContactsCONTENT_URI, values);  

long rawContactId = ContentUrisparseId(rawContactUri);二、对联系人的基本 *** 作(8)  

// 向data表插入姓名数据  

if (name != "")  

{  

valuesclear();  

valuesput(DataRAW_CONTACT_ID, rawContactId);  

valuesput(DataMIMETYPE,   

StructuredNameCONTENT_ITEM_TYPE);  

valuesput(StructuredNameGIVEN_NAME, name);  

getContentResolver()insert(ContactsContractDataCONTENT_URI,   

values);  

}  

  

// 向data表插入电话数据  

if (phoneNum != "")  

{  

valuesclear();  

valuesput(DataRAW_CONTACT_ID, rawContactId);  

valuesput(DataMIMETYPE, PhoneCONTENT_ITEM_TYPE);  

valuesput(PhoneNUMBER, phoneNum);  

valuesput(PhoneTYPE, PhoneTYPE_MOBILE);  

getContentResolver()insert(ContactsContractDataCONTENT_URI,   

values);  

}

删除联系人

我们只需要将raw_contacts表中指定RawContactID的

行删除,其他表中与之关联的数据都会自动删除。

public void delete(long rawContactId)  

{  

getContentResolver()delete(ContentUriswithAppendedId(RawContac  

tsCONTENT_URI, rawContactId), null, null);  

}

更新联系人

联系人的所有信息都是保存在data表中,所以要更新联系人,我们只需要根

据RawContactID和MIMETYPE修改data表中的内容。

ContentValues values = new ContentValues();  

valuesput(PhoneNUMBER, “123");  

valuesput(PhoneTYPE, PhoneTYPE_MOBILE);  

String Where = ContactsContractDataRAW_CONTACT_ID + " =  AND   

" + ContactsContractDataMIMETYPE + " = ";  

String[] WhereParams = new String[]{"5", PhoneCONTENT_ITEM_TYPE};  

getContentResolver()update(ContactsContractDataCONTENT_URI,   

values, Where, WhereParams);

如若满意,请点击右侧采纳答案,如若还有问题,请点击追问

希望我的回答对您有所帮助,望采纳!

~ O(∩_∩)O~

数据库很多,但是安卓直接支持的数据库只有sqlite一种。如果要使用其它的非本地数据库,你得建立连接,采用webservice或>

1首先需要安装MySQL Server 51和navicat for mysql。这个安装是很简单的,网上很多教程,和安装一般软件差不多。只有在安装MySQL Server 51时,要注意选择字符编码为gb2312(中文)那个选项。

2 使用navicat for mysql导入数据文件

a打开navicat for mysql,和localhost本地数据库连接,就可以看到刚才建立的数据库和表,

b可以导入本地的txt数据文件,注意保持格式正确,

c下面一步要注意一下,如果数据库中有中文数据,编码格式一定要选择是中文的GB2312,

d然后间隔符为空格(根据txt中的具体情况来定),

e并选择目标表,将每一列一一对应,即可导入。

以上就是关于android 怎么连接数据库全部的内容,包括:android 怎么连接数据库、android 怎么读取数据库中的数据、android app如何从数据库中获取需要的数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10179443.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存