




已閱讀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開始 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025-2026學(xué)年江蘇省東??h晶都雙語(yǔ)學(xué)校數(shù)學(xué)三上期末考試模擬試題含解析
- 2025-2026學(xué)年甘肅省慶陽(yáng)市慶陽(yáng)縣數(shù)學(xué)三上期末模擬試題含解析
- 2025-2026學(xué)年德宏傣族景頗族自治州數(shù)學(xué)三上期末達(dá)標(biāo)檢測(cè)試題含解析
- 2024年隴南地區(qū)徽縣三上數(shù)學(xué)期末考試模擬試題含解析
- 公共衛(wèi)生管理 (2)課件
- 自考2025年行政管理商業(yè)模式試題及答案
- 精細(xì)管理下的執(zhí)業(yè)藥師試題及答案
- 自考行政管理2025年求知若渴試題及答案分享
- 護(hù)理理論2025年考試試題及答案
- 2025年執(zhí)業(yè)醫(yī)師考試住院醫(yī)師規(guī)范化培訓(xùn)試題及答案
- 體育運(yùn)動(dòng)中的功能性訓(xùn)練
- 足浴店消防管理制度
- AI賦能光伏電站視頻監(jiān)控系統(tǒng)解決方案
- 【我的祖國(guó)詩(shī)朗誦稿董卿】我的祖國(guó)詩(shī)朗誦稿
- 外墻 吊繩滑板油漆安全施工方案
- 供應(yīng)商績(jī)效評(píng)估表績(jī)效管理
- 麥克維爾冷水機(jī)組使用說(shuō)明書
- 第三單元整體教學(xué)設(shè)計(jì) 統(tǒng)編版語(yǔ)文八年級(jí)上冊(cè)
- .司機(jī)服務(wù)禮儀培訓(xùn)
- 工廠車輛道閘系統(tǒng)設(shè)計(jì)方案
- 旅游專業(yè)群建設(shè)方案
評(píng)論
0/150
提交評(píng)論