




已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
北京傳智播客教育 ,北京傳智播客教育 ,訪問(wèn)SharedPreferences中的數(shù)據(jù),訪問(wèn)SharedPreferences中的數(shù)據(jù)代碼如下: SharedPreferences sharedPreferences = getSharedPreferences(“itcast“, Context.MODE_PRIVATE); /getString()第二個(gè)參數(shù)為缺省值,如果preference中不存在該key,將返回缺省值 String name = sharedPreferences.getString(“name“, “); int age = sharedPreferences.getInt(“age“, 1); 如果訪問(wèn)其他應(yīng)用中的Preference,前提條件是:該preference創(chuàng)建時(shí)指定了Context.MODE_WORLD_READABLE或者Context.MODE_WORLD_WRITEABLE權(quán)限。如:有個(gè)為cn.itcast.action的應(yīng)用使用下面語(yǔ)句創(chuàng)建了preference。 getSharedPreferences(“itcast“, Context.MODE_WORLD_READABLE); 其他應(yīng)用要訪問(wèn)上面應(yīng)用的preference,首先需要?jiǎng)?chuàng)建上面應(yīng)用的Context,然后通過(guò)Context 訪問(wèn)preference ,訪問(wèn)preference時(shí)會(huì)在應(yīng)用所在包下的shared_prefs目錄找到preference : Context otherAppsContext = createPackageContext(“cn.itcast.action“, Context.CONTEXT_IGNORE_SECURITY); SharedPreferences sharedPreferences = otherAppsContext.getSharedPreferences(“itcast“, Context.MODE_WORLD_READABLE); String name = sharedPreferences.getString(“name“, “); int age = sharedPreferences.getInt(“age“, 0); 如果不通過(guò)創(chuàng)建Context訪問(wèn)其他應(yīng)用的preference,可以以讀取xml文件方式直接訪問(wèn)其他應(yīng)用preference對(duì)應(yīng)的xml文件,如: File xmlFile = new File(“/data/data/shared_prefs/itcast.xml”);/應(yīng)替換成應(yīng)用的包名,北京傳智播客教育 ,北京傳智播客教育 ,使用嵌入式關(guān)系型SQLite數(shù)據(jù)庫(kù)存儲(chǔ)數(shù)據(jù),除了可以使用文件或SharedPreferences存儲(chǔ)數(shù)據(jù),還可以選擇使用SQLite數(shù)據(jù)庫(kù)存儲(chǔ)數(shù)據(jù)。 在Android平臺(tái)上,集成了一個(gè)嵌入式關(guān)系型數(shù)據(jù)庫(kù)SQLite,SQLite3支持 NULL、INTEGER、REAL(浮點(diǎn)數(shù)字)、TEXT(字符串文本)和BLOB(二進(jìn)制對(duì)象)數(shù)據(jù)類型,雖然它支持的類型雖然只有五種,但實(shí)際上sqlite3也接受varchar(n)、char(n)、decimal(p,s) 等數(shù)據(jù)類型,只不過(guò)在運(yùn)算或保存時(shí)會(huì)轉(zhuǎn)成對(duì)應(yīng)的五種數(shù)據(jù)類型。 SQLite最大的特點(diǎn)是你可以保存任何類型的數(shù)據(jù)到任何字段中,無(wú)論這列聲明的數(shù)據(jù)類型是什么。例如:可以在Integer字段中存放字符串,或者在布爾型字段中存放浮點(diǎn)數(shù),或者在字符型字段中存放日期型值。 但有一種情況例外:定義為INTEGER PRIMARY KEY的字段只能存儲(chǔ)64位整數(shù), 當(dāng)向這種字段中保存除整數(shù)以外的數(shù)據(jù)時(shí),將會(huì)產(chǎn)生錯(cuò)誤。 另外, SQLite 在解析CREATE TABLE 語(yǔ)句時(shí),會(huì)忽略 CREATE TABLE 語(yǔ)句中跟在字段名后面的數(shù)據(jù)類型信息,如下面語(yǔ)句會(huì)忽略 name字段的類型信息: CREATE TABLE person (personid integer primary key autoincrement, name varchar(20) SQLite可以解析大部分標(biāo)準(zhǔn)SQL語(yǔ)句,如: 查詢語(yǔ)句:select * from 表名 where 條件子句 group by 分組字句 having . order by 排序子句 如:select * from person select * from person order by id desc select name from person group by name having count(*)1 分頁(yè)SQL與mysql類似,下面SQL語(yǔ)句獲取5條記錄,跳過(guò)前面3條記錄 select * from Account limit 5 offset 3 或者 select * from Account limit 3,5 插入語(yǔ)句:insert into 表名(字段列表) values(值列表)。如: insert into person(name, age) values(傳智,3) 更新語(yǔ)句:update 表名 set 字段名=值 where 條件子句。如:update person set name=傳智 where id=10 刪除語(yǔ)句:delete from 表名 where 條件子句。如:delete from person where id=10,北京傳智播客教育 ,北京傳智播客教育 ,使用SQLiteDatabase操作SQLite數(shù)據(jù)庫(kù),Android提供了一個(gè)名為SQLiteDatabase的類,該類封裝了一些操作數(shù)據(jù)庫(kù)的API,使用該類可以完成對(duì)數(shù)據(jù)進(jìn)行添加(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡(jiǎn)稱為CRUD)。對(duì)SQLiteDatabase的學(xué)習(xí),我們應(yīng)該重點(diǎn)掌握execSQL()和rawQuery()方法。 execSQL()方法可以執(zhí)行insert、delete、update和CREATE TABLE之類有更改行為的SQL語(yǔ)句; rawQuery()方法可以執(zhí)行select語(yǔ)句。 execSQL()方法的使用例子: SQLiteDatabase db = ; db.execSQL(“insert into person(name, age) values(傳智播客, 4)“); db.close(); 執(zhí)行上面SQL語(yǔ)句會(huì)往person表中添加進(jìn)一條記錄,在實(shí)際應(yīng)用中, 語(yǔ)句中的“傳智播客”這些參數(shù)值應(yīng)該由用戶輸入界面提供,如果把用戶輸入的內(nèi)容原樣組拼到上面的insert語(yǔ)句, 當(dāng)用戶輸入的內(nèi)容含有單引號(hào)時(shí),組拼出來(lái)的SQL語(yǔ)句就會(huì)存在語(yǔ)法錯(cuò)誤。要解決這個(gè)問(wèn)題需要對(duì)單引號(hào)進(jìn)行轉(zhuǎn)義,也就是把單引號(hào)轉(zhuǎn)換成兩個(gè)單引號(hào)。有些時(shí)候用戶往往還會(huì)輸入像“ execSQL(String sql, Object bindArgs)方法的第一個(gè)參數(shù)為SQL語(yǔ)句,第二個(gè)參數(shù)為SQL語(yǔ)句中占位符參數(shù)的值,參數(shù)值在數(shù)組中的順序要和占位符的位置對(duì)應(yīng)。,http:/www.anzhuo.cc/ 安卓手機(jī)論壇,北京傳智播客教育 ,北京傳智播客教育 ,使用SQLiteDatabase操作SQLite數(shù)據(jù)庫(kù),SQLiteDatabase的rawQuery() 用于執(zhí)行select語(yǔ)句,使用例子如下: SQLiteDatabase db = ; Cursor cursor = db.rawQuery(“select * from person”, null); while (cursor.moveToNext() int personid = cursor.getInt(0); /獲取第一列的值,第一列的索引從0開(kāi)始 String name = cursor.getString(1);/獲取第二列的值 int age = cursor.getInt(2);/獲取第三列的值 cursor.close(); db.close(); rawQuery()方法的第一個(gè)參數(shù)為select語(yǔ)句;第二個(gè)參數(shù)為select語(yǔ)句中占位符參數(shù)的值,如果select語(yǔ)句沒(méi)有使用占位符,該參數(shù)可以設(shè)置為null。帶占位符參數(shù)的select語(yǔ)句使用例子如下: Cursor cursor = db.rawQuery(“select * from person where name like ? and age=?“, new String“%傳智%“, “4“); Cursor是結(jié)果集游標(biāo),用于對(duì)結(jié)果集進(jìn)行隨機(jī)訪問(wèn),如果大家熟悉jdbc, 其實(shí)Cursor與JDBC中的ResultSet作用很相似。使用moveToNext()方法可以將游標(biāo)從當(dāng)前行移動(dòng)到下一行,如果已經(jīng)移過(guò)了結(jié)果集的最后一行,返回結(jié)果為false,否則為true。另外Cursor 還有常用的moveToPrevious()方法(用于將游標(biāo)從當(dāng)前行移動(dòng)到上一行,如果已經(jīng)移過(guò)了結(jié)果集的第一行,返回值為false,否則為true )、moveToFirst()方法(用于將游標(biāo)移動(dòng)到結(jié)果集的第一行,如果結(jié)果集為空,返回值為false,否則為true )和moveToLast()方法(用于將游標(biāo)移動(dòng)到結(jié)果集的最后一行,如果結(jié)果集為空,返回值為false,否則為true ) 。,5,Activity,Activity,A visual user interface 通過(guò)view管理UI 每一個(gè)有用戶界面的應(yīng)用至少包含一個(gè)activity 一個(gè)應(yīng)用可以有多個(gè)activity,其中一個(gè)作為main activity
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 造紙行業(yè)的品牌策略與價(jià)值傳遞考核試卷
- 谷物儲(chǔ)存的糧食防潮技術(shù)考核試卷
- 神經(jīng)科學(xué)與心理學(xué)研究出版考核試卷
- 茶葉栽培的農(nóng)業(yè)知識(shí)與技術(shù)推廣考核試卷
- 電機(jī)在電力工具中的應(yīng)用評(píng)估考核試卷
- 聚己內(nèi)酰胺纖維性能測(cè)試考核試卷
- 砼結(jié)構(gòu)構(gòu)件的施工材料管理考核試卷
- 拍賣行業(yè)網(wǎng)絡(luò)安全防護(hù)考核試卷
- 罐頭食品生產(chǎn)衛(wèi)生管理考核試卷
- 服務(wù)機(jī)器人技術(shù)成果轉(zhuǎn)化與應(yīng)用考核試卷
- 遼寧省沈陽(yáng)市鐵西區(qū)2023-2024學(xué)年七年級(jí)下學(xué)期期末數(shù)學(xué)試題
- 2024年紫金山科技產(chǎn)業(yè)發(fā)展集團(tuán)招聘筆試沖刺題(帶答案解析)
- 駕駛員心理健康教育培訓(xùn)
- 2024年四川二造《建設(shè)工程造價(jià)管理基礎(chǔ)知識(shí)》考前強(qiáng)化練習(xí)題庫(kù)300題(含解析)
- MOOC 音樂(lè)心理學(xué)-上海師范大學(xué) 中國(guó)大學(xué)慕課答案
- 乙結(jié)冗長(zhǎng)癥護(hù)理查房
- 2020年8月自考00158資產(chǎn)評(píng)估試題及答案含解析
- 財(cái)政預(yù)算監(jiān)督培訓(xùn)課件
- 秦腔-全折劇譜《殺廟》樂(lè)譜
- 多功能地鐵換乘站綜合概要課件
- 導(dǎo)醫(yī)接待工作中的應(yīng)急處理方法
評(píng)論
0/150
提交評(píng)論