android *** 作sqlite数据库需要new一个新thread吗

android *** 作sqlite数据库需要new一个新thread吗,第1张

不需要,如果sqlite查询很耗时的话可以使用thread异步查询。

SQLite是轻量级嵌入式数据库引擎,它支持 SQL 语言,并且只利用很少的内存就有很好的性能。此外它还是开源的,任何人都可以使用它。许多开源项目((Mozilla, PHP, Python)都使用了 SQLiteSQLite 由以下几个组件组成:SQL 编译器、内核、后端以及附件。SQLite 通过利用虚拟机和虚拟数据库引擎(VDBE),使调试、修改和扩展 SQLite 的内核变得更加方便。

Android 集成了 SQLite 数据库 Android 在运行时(run-time)集成了 SQLite,所以每个 Android 应用程序都可以使用 SQLite 数据库。

数据库存储在 data/< 项目文件夹 >/databases/ 下。 Android 开发中使用 SQLite 数据库 Activites 可以通过 Content Provider 或者 Service 访问一个数据库。

Android 提供了 SQLiteOpenHelper 创建一个数据库,只要继承 SQLiteOpenHelper 类,就可以轻松的创建数据库。SQLiteOpenHelper 类根据开发应用程序的需要,封装了创建和更新数据库使用的逻辑。

SQLiteOpenHelper 的子类,至少需要实现三个方法

1 构造函数,调用父类 SQLiteOpenHelper 的构造函数。这个方法需要四个参数:上下文环境(例如,一个 Activity),数据库名字,一个可选的游标工厂(通常是 Null),一个代表你正在使用的数据库模型版本的整数。

2 onCreate()方法,它需要一个 SQLiteDatabase 对象作为参数,根据需要对这个对象填充表和初始化数据。

3 onUpgrage() 方法,它需要三个参数,一个 SQLiteDatabase 对象,一个旧的版本号和一个新的版本号,这样就可以清楚如何把一个数据库从旧的模型转变到新的模型。

如果是模拟器,在android 的SDK中有一个adb组件,通过adb先连上模拟器

如果是真机,也是需要你先通过adb连接真机,之后类似linux命令行 *** 作

进入应用数据库所在目录 cd /////

sqlite3 数据库文件名

Android为数据存储提供了多种方式,分别有如下几种:

文件

SharedPreferences

SQLite数据库

内容提供者(Content provider)

网络

使用文件进行数据存储

首先给大家介绍使用文件如何对数据进行存储,Activity提供了openFileOutput()方法可以用于把数据输出到文件中,具体的实现过程与在J2SE环境中保存数据到文件中是一样的。

复制代码 代码如下:

public class FileActivity extends Activity {

@Override public void onCreate(Bundle savedInstanceState) {

FileOutputStream outStream = thisopenFileOutput("csdnttxt", ContextMODE_PRIVATE);

outStreamwrite("CSDN"getBytes());

outStreamclose();

}

}

openFileOutput()方法的第一参数用于指定文件名称,不能包含路径分隔符“/” ,如果文件不存在,Android 会自动创建它。创建的文件保存在/data/data/<package name>/files目录,如: /data/data/cncsdnaction/files/csdntxt ,通过点击Eclipse菜单“Window”-“Show View”-“Other”,在对话窗口中展开android文件夹,选择下面的File Explorer视图,然后在File Explorer视图中展开/data/data/<package name>/files目录就可以看到该文件。

openFileOutput()方法的第二参数用于指定 *** 作模式,有四种模式,分别为: ContextMODE_PRIVATE = 0

ContextMODE_APPEND = 32768

ContextMODE_WORLD_READABLE = 1

ContextMODE_WORLD_WRITEABLE = 2

ContextMODE_PRIVATE:为默认 *** 作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用ContextMODE_APPEND

ContextMODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。

ContextMODE_WORLD_READABLE和ContextMODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。

MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。

如果希望文件被其他应用读和写,可以传入:

openFileOutput("csdntxt", ContextMODE_WORLD_READABLE + ContextMODE_WORLD_WRITEABLE);

android有一套自己的安全模型,当应用程序(apk)在安装时系统就会分配给他一个userid,当该应用要去访问其他资源比如文件的时候,就需要userid匹配。默认情况下,任何应用创建的文件,sharedpreferences,数据库都应该是私有的(位于/data/data/<package name>/files),其他程序无法访问。除非在创建时指定了ContextMODE_WORLD_READABLE或者ContextMODE_WORLD_WRITEABLE ,只有这样其他程序才能正确访问。

读取文件内容

如果要打开存放在/data/data/<package name>/files目录应用私有的文件,可以使用Activity提供openFileInput()方法。

FileInputStream inStream = thisgetContext()openFileInput("csdntxt");

Logi("FileTest", readInStream(inStream));

readInStream()的方法请看本页下面备注。

或者直接使用文件的绝对路径:

File file = new File("/data/data/cncsdnaction/files/csdntxt");

FileInputStream inStream = new FileInputStream(file);

Logi("FileTest", readInStream(inStream));

注意:上面文件路径中的“cncsdnaction”为应用所在包,当你在编写代码时应替换为你自己应用使用的包。

对于私有文件只能被创建该文件的应用访问,如果希望文件能被其他应用读和写,可以在创建文件时,指定ContextMODE_WORLD_READABLE和ContextMODE_WORLD_WRITEABLE权限。

Activity还提供了getCacheDir()和getFilesDir()方法:

getCacheDir()方法用于获取/data/data/<package name>/cache目录

getFilesDir()方法用于获取/data/data/<package name>/files目录

完全可以啊,你获得数据库对象,好像是Sqldatebase

的对象。直接 *** 作数据库添加,删除,修改。跟Ativity没啥关系吧。就好比MFC中不通界面都可以对数据库进行 *** 作。只要数据库对象传递过去就行。

参考如下内容:

一、 联系人数据库

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

/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获取该联系人的各数据了。

[html] view plaincopy

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

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();

[html] view plaincopy

// 读取号码

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

先写一个类继承SQLiteOpenHelper,然后在onCreate用dbexecSQL创建数据库,要调用数据库的时候先new一个DataBaseHelper,并用SQLiteDatabase去获取DataBaseHelper的写或者读 *** 作就行了

通过cmd可对数据库进行访问,现在开发android一般都用的eclipse+adt+sdk;进入cmd输入adb

shell

,然后

cd

/data/data

再ls

显示所有的包名,cd

到你的包名,然后

cd

databases

再ls

显示你的数据库名

,最后

sqlite3

数据库名

就可以对数据库进行 *** 作了。

一、引入

数据库创建的问题解决了,接下来就该使用数据库实现应用程序功能的时候了。基

本的 *** 作包括创建、读取、更新、删除,即我们通常说的 CRUD(Create, Read, Update, Delete)。

在实现这些 *** 作的时候,我们会使用到两个比较重要的类 SQLiteDatabase 类和 Cursor 类。

二、创建表

1,execSQL(String sql):执行一条 sql 语句,且执行 *** 作不能为 SELECT

因为它的返回值为 void,所以推荐使用 insert、update 方法等

2,execSQL (String sql,Object[] bindArgs)

sql:执行一条 sql 语句

bindArgs:为 sql 语句中的赋值

三、添加数据

1、execSQL(String sql)

2、使用对象的 insert 方法

ContentValues values = new ContentValues();

valuesput(USERNAME, usergetUsername());

valuesput(PASSWORD, usergetPassword());

dbinsert(TABLE_NAME, null, values);

参数:

table:数据库中的表名

nullColumnHack:指定默认插入字段,为 null 时能插入数据

values:表示插入字段所对应的值,使用 put 方法。

四、删除数据

1、execSQL(String sql)

2、使用对象的 delete 方法

String whereClaues="_id=";

String [] whereArgs={StringvalueOf(id)};

//dbdelete(TABLE_NAME, "_id="+id, null);

dbdelete(TABLE_NAME, whereClaues, whereArgs);

参数

table:数据库的表名

whereClause:where 子句,比如:_id=

whereArgs:where 子句中的值

五、修改数据

1、execSQL(String sql)

2、使用对象的 delete 方法

ContentValues values = new ContentValues();

valuesput(USERNAME, usergetUsername());

valuesput(PASSWORD, usergetPassword());

String whereClaues="_id=";

String [] whereArgs={StringvalueOf(usergetId())};

dbupdate(TABLE_NAME, values, whereClaues, whereArgs);

参数

table:数据库的表名

values:代表要修改的值,修改方法还是 put(key,values)

whereClause:条件子句,比如 id=,name=

whereArgs:为 whereClause 中的赋值,比如:new String[]{"1","张三"}

图:

参考代码:

程序内使用SQLite数据库是通过SQLiteOpenHelper进行 *** 作

1       自己写个类继承SQLiteOpenHelper,重写以下3个方法

public void onCreate(SQLiteDatabase db)

{//创建数据库时的 *** 作,如建表}

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)

{

//版本更新的 *** 作

}

2    通过SQLiteOpenHelper的getWritableDatabase()获得一个SQLiteDatabase数据库,以后的 *** 作都是对SQLiteDatabase进行 *** 作。

3       对得到的SQLiteDatabase对象进行增,改,删,查等 *** 作。

代码

package cxmyNote;

import androidcontentContentValues;

import androidcontentContext;

import androidcontentIntent;

import androiddatabaseCursor;

import androiddatabasesqliteSQLiteDatabase;

import androiddatabasesqliteSQLiteOpenHelper;

//DBOptions for login

public class DBOptions {

private static final String DB_NAME = "notesdb";

private static final String DB_CREATE="create table logininf(name text,pwd text)";

public class DBHelper extends SQLiteOpenHelper

{

public DBHelper(Context context) {

super(context,DB_NAME, null, 1);

}

@Override

public void onCreate(SQLiteDatabase db) {

// TODO Auto-generated method stub

//建表

dbexecSQL(DB_CREATE);

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

// TODO Auto-generated method stub

dbexecSQL("drop table if exists logininf");

onCreate(db);

}

}

private Context context;

private SQLiteDatabase db;

private DBHelper dbHelper;

public  DBOptions(Context context)

{

thiscontext = context;

dbHelper = new DBHelper(context);

db=dbHelpergetReadableDatabase();

}

//自己写的方法,对数据库进行 *** 作

public String getName()

{

Cursor cursor = dbrawQuery("select name from logininf", null);

cursormoveToFirst();

return cursorgetString(0);

}

public int changePWD(String oldP,String pwd)

{

ContentValues values = new ContentValues();

valuesput("pwd", pwd);

return dbupdate("logininf", values,"pwd="+oldP, null);

}

}

insert方法插入的一行记录使用ContentValus存放,ContentValues类似于Map,它提供了put(String key, Xxx value)(其中key为数据列的列名)方法用于存入数据、getAsXxxx(String key)方法用于取出数据

以上就是关于android *** 作sqlite数据库需要new一个新thread吗全部的内容,包括:android *** 作sqlite数据库需要new一个新thread吗、android平台上怎么 *** 作sqlite数据库、android有哪几种方式进行数据库访问等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存