




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
玩轉(zhuǎn)SQLite系列SQLite數(shù)據(jù)庫(kù)應(yīng)用案例實(shí)現(xiàn)歷史搜索記錄一.編寫一個(gè)歷史搜索記錄實(shí)例對(duì)象packagecn.bluemobi.dylan.sqlite;importjava.util.Date;/***搜索記錄的操作對(duì)象*CreatedbyAdministratoron2016-11-20.*/publicclassHistory{/***id主鍵,自增*/privateintid;/***搜索的內(nèi)容*/privateStringcontent;/***搜索的時(shí)間*/privateStringtime;publicintgetId(){returnid;}publicvoidsetId(intid){this.id=id;}publicStringgetContent(){returncontent;}publicvoidsetContent(Stringcontent){this.content=content;}publicStringgetTime(){returntime;}publicvoidsetTime(Stringtime){this.time=time;}}二.編寫一個(gè)操作數(shù)據(jù)庫(kù)的管理工具類packagecn.bluemobi.dylan.sqlite;importandroid.content.ContentValues;importandroid.database.Cursor;importandroid.database.sqlite.SQLiteDatabase;importandroid.os.Environment;importjava.io.File;importjava.util.ArrayList;importjava.util.List;/***數(shù)據(jù)庫(kù)操作管理類*CreatedbyAdministratoron2016-11-19.*/publicclassDBManager{privatestaticvolatileDBManagerdbManager;privateSQLiteDatabasesqLiteDatabase;privateDBManager(){openDataBase();createTable();}publicstaticDBManagergetDBManager(){if(dbManager==null){synchronized(DBManager.class){if(dbManager==null){dbManager=newDBManager();}}}returndbManager;}/***數(shù)據(jù)庫(kù)名稱*/privatefinalStringDATABASE_NAME="info.db";/***表名*/privatefinalStringTABLE_NAME="history";/***表格所包含的字段*/privateclassHistoryDbColumn{/***字段一id*/publicstaticfinalStringID="id";/***字段二內(nèi)容*/publicstaticfinalStringCONTENT="name";/***字段三時(shí)間*/publicstaticfinalStringTIME="time";}/***1.創(chuàng)建或打開數(shù)據(jù)庫(kù)連接**/privatevoidopenDataBase(){FiledataBaseFile=newFile(Environment.getExternalStorageDirectory()+"/sqlite",DATABASE_NAME);if(!dataBaseFile.getParentFile().exists()){dataBaseFile.mkdirs();}sqLiteDatabase=SQLiteDatabase.openOrCreateDatabase(dataBaseFile,null);}/*****2.創(chuàng)建表*/privatevoidcreateTable(){Stringsql="CREATETABLE"+"IFNOTEXISTS"+TABLE_NAME+"("+HistoryDbColumn.ID+"IntegerPRIMARYKEYAUTOINCREMENT,"+HistoryDbColumn.CONTENT+"varchar,"+HistoryDbColumn.TIME+"datetime)";sqLiteDatabase.execSQL(sql);}/***插入一條數(shù)據(jù)**@paramhistory*@return*/publiclonginsert(Historyhistory){ContentValuescontentValues=newContentValues();contentValues.put(HistoryDbColumn.CONTENT,history.getContent());contentValues.put(HistoryDbColumn.TIME,history.getTime());longnum=sqLiteDatabase.insert(TABLE_NAME,null,contentValues);returnnum;}/***根據(jù)id刪除一條數(shù)據(jù)**@paramid*@return*/publiclongdelete(intid){longnum=sqLiteDatabase.delete(TABLE_NAME,HistoryDbColumn.ID+"=?",newString[]{String.valueOf(id)});returnnum;}/***根據(jù)id修改一條數(shù)據(jù)**@paramid*@return*/publiclongupdate(Historyhistory,intid){ContentValuescontentValues=newContentValues();contentValues.put(HistoryDbColumn.CONTENT,history.getContent());contentValues.put(HistoryDbColumn.TIME,history.getTime());longnum=sqLiteDatabase.update(TABLE_NAME,contentValues,HistoryDbColumn.ID+"=?",newString[]{String.valueOf(id)});returnnum;}/***根據(jù)id查詢一條數(shù)據(jù)**@paramid*@return*/publicHistoryqurey(intid){Historyhistory=null;Cursorcursor=sqLiteDatabase.query(TABLE_NAME,null,HistoryDbColumn.ID+"=?",newString[]{String.valueOf(id)},null,null,null);if(cursor!=null){if(cursor.moveToNext()){history=newHistory();history.setId(cursor.getInt(cursor.getColumnIndex(HistoryDbColumn.ID)));history.setContent(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.CONTENT)));history.setTime(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.TIME)));}}returnhistory;}/***根據(jù)id查詢一條數(shù)據(jù)*倒序**@return*/publicList<History>queryAll(){List<History>historys=newArrayList<>();Cursorcursor=sqLiteDatabase.query(TABLE_NAME,null,null,null,null,null,HistoryDbColumn.TIME+"desc");if(cursor!=null){while(cursor.moveToNext()){Historyhistory=newHistory();history.setId(cursor.getInt(cursor.getColumnIndex(HistoryDbColumn.ID)));history.setContent(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.CONTENT)));history.setTime(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.TIME)));historys.add(history);}}returnhistorys;}/***根據(jù)內(nèi)容查詢一條數(shù)據(jù)**@return*/publicHistoryqueryByContent(Stringcontent){Historyhistory=null;Cursorcursor=sqLiteDatabase.query(TABLE_NAME,null,HistoryDbColumn.CONTENT+"=?",newString[]{content},null,null,null);if(cursor!=null){if(cursor.moveToNext()){history=newHistory();history.setId(cursor.getInt(cursor.getColumnIndex(HistoryDbColumn.ID)));history.setContent(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.CONTENT)));history.setTime(cursor.getString(cursor.getColumnIndex(HistoryDbColumn.TIME)));}}returnhistory;}}三.搜索對(duì)話框的布局文件<?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:minHeight="250dp"android:orientation="vertical"><cn.bluemobi.dylan.sqlite.SearchViewandroid:id="@+id/sv"android:padding="10dp"android:background="@color/colorPrimaryDark"android:layout_width="match_parent"android:layout_height="wrap_content"></cn.bluemobi.dylan.sqlite.SearchView><ListViewandroid:id="@+id/lv"android:layout_width="match_parent"android:layout_height="match_parent"></ListView><TextViewandroid:id="@+id/tv"android:layout_gravity="center"android:gravity="center"android:layout_weight="1"android:layout_width="match_parent"android:layout_height="match_parent"android:text="暫無(wú)搜索記錄"/></LinearLayout>四.編寫功能代碼packagecn.bluemobi.dylan.sqlite;importandroid.app.Dialog;importandroid.os.Bundle;importandroid.support.annotation.Nullable;importandroid.support.v7.app.AppCompatActivity;importandroid.util.Log;importandroid.view.Gravity;importandroid.view.View;importandroid.view.WindowManager;importandroid.widget.Button;importandroid.widget.EditText;importandroid.widget.ListView;importandroid.widget.TextView;importandroid.widget.Toast;importjava.util.Date;importjava.util.List;importcn.bluemobi.dylan.sqlite.adapter.CommonAdapter;importcn.bluemobi.dylan.sqlite.adapter.CommonViewHolder;/***SQLite應(yīng)用案例實(shí)現(xiàn)搜索記錄*CreatedbyAdministratoron2016-11-20.*/publicclassSearchActivityextendsAppCompatActivityimplementsView.OnClickListener{privateEditTextet;privateListViewlv;privateTextViewtv;privateDialogdialog;privateSearchViewsv;privateButtonbt;privateList<History>histories;privateCommonAdapter<History>commonAdapter;privatefinalintMAX_ITME=5;privatevoidassignViews(){et=(EditText)findViewById(R.id.et);}@OverrideprotectedvoidonCreate(@NullableBundlesavedInstanceState){super.onCreate(savedInstanceState);getSupportActionBar().setTitle("SQLite應(yīng)用案例實(shí)現(xiàn)搜索記錄");setContentView(R.layout.ac_search);assignViews();intiDialog();addListener();initData();}/***添加按鈕監(jiān)聽*/privatevoidaddListener(){et.setOnClickListener(this);}/****初始化搜索對(duì)話框*/privatevoidintiDialog(){dialog=newDialog(this,R.style.Dialog_FullScreen);dialog.setContentView(R.layout.dialog_search);dialog.getWindow().setGravity(Gravity.TOP);dialog.setCanceledOnTouchOutside(true);dialog.setCancelable(true);WindowManager.LayoutParamslp=dialog.getWindow().getAttributes();lp.width=WindowManager.LayoutParams.MATCH_PARENT;lp.height=WindowManager.LayoutParams.WRAP_CONTENT;dialog.getWindow().setAttributes(lp);lv=(ListView)dialog.findViewById(R.id.lv);tv=(TextView)dialog.findViewById(R.id.tv);sv=(SearchView)dialog.findViewById(R.id.sv);bt=(Button)dialog.findViewById(R.id.bt);bt.setOnClickListener(this);lv.setEmptyView(tv);}/***初始化數(shù)據(jù)*/privatevoidinitData(){commonAdapter=newCommonAdapter<History>(this,histories,R.layout.item_for_search){@OverrideprotectedvoidconvertView(CommonViewHoldercommonViewHolder,Historyhistory){TextViewtv=commonViewHolder.get(R.id.textView);tv.setText(history.getContent());}};lv.setAdapter(commonAdapter);notifyAdapter();}@OverridepublicvoidonClick(Viewv){switch(v.getId()){caseR.id.et:if(!dialog.isShowing()){dialog.show();}break;caseR.id.bt:addHistory();break;}}/***點(diǎn)擊搜索按鈕新增一條記錄*/privatevoidaddHistory(){StringinputText=sv.getInputText();if(inputText.isEmpty()){Toast.makeText(this,"請(qǐng)輸入內(nèi)容進(jìn)行搜索",Toast.LENGTH_SHORT
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 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年P(guān)P膠水項(xiàng)目規(guī)劃申請(qǐng)報(bào)告模板
- 2025年電機(jī)及電動(dòng)操項(xiàng)目申請(qǐng)報(bào)告
- 做框架 教學(xué)課件
- 怎樣使用課件教學(xué)
- 文庫(kù)發(fā)布:護(hù)理倫理
- 美學(xué)欣賞教學(xué)課件
- 敬畏生命主題班會(huì)課件
- 認(rèn)識(shí)整點(diǎn)的教學(xué)課件
- 散光護(hù)理措施
- 醫(yī)院教學(xué)類培訓(xùn)課件
- 羅蘭貝格戰(zhàn)略性品牌管理工具Profiler簡(jiǎn)介
- 中國(guó)工商銀行個(gè)人住房貸款申請(qǐng)審批表
- 2023-2024學(xué)年四川省雅安市小學(xué)語(yǔ)文一年級(jí)下冊(cè)期末提升提分卷
- 2023年培黎職業(yè)學(xué)院高職單招(語(yǔ)文)試題庫(kù)含答案解析
- GB/T 39024-2020木桿鉛筆黑鉛芯分類和直徑
- GB/T 32957-2016液壓和氣動(dòng)系統(tǒng)設(shè)備用冷拔或冷軋精密內(nèi)徑無(wú)縫鋼管
- GB/T 18380.33-2022電纜和光纜在火焰條件下的燃燒試驗(yàn)第33部分:垂直安裝的成束電線電纜火焰垂直蔓延試驗(yàn)A類
- cence湘儀TDZ4K離心機(jī)使用說明
- qcpcb制作、檢驗(yàn)及包裝送貨
- 人因工程學(xué)課后習(xí)題及解答
- 供應(yīng)商管理培訓(xùn) 課件
評(píng)論
0/150
提交評(píng)論