国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

淺析Android手機衛士之號碼歸屬地查詢

2019-12-12 06:32:15
字體:
來源:轉載
供稿:網友

使用小米號碼歸屬地數據庫,有兩張表data1和data2

先查詢data1表,把手機號碼截取前7位

select outkey from data1 where id=”前七位手機號”

再查詢data2表,

select location from data2 where id=”上面查出的outkey”

可以使用子查詢

select location from data2 where id=(select outkey from data1 where id=”前7位手機號”)

創建數據庫工具類

新建一個包xxx.db.dao

新建一個類NumberAddressUtils,新建一個靜態方法queryNumber

調用SQLiteDatabase.openDatabase()方法,獲取到SQLiteDatabase對象,參數:數據庫路徑(/data/data/包名/files/xxx.db),游標工廠(null),打開方式(SQLiteDatabse.OPEN_READONLY)

把數據庫address.db拷貝到 /data/data/包名/files/目錄里面

調用SQLiteDatabase對象的rawQuery()方法,獲取到Cursor對象,查詢數據,參數:sql語句,string[]條件數組

例如:select location from data2 where id=(select outkey from data1 where id=?) ,new String[]{phone.subString(0,7)}

while循環Cursor對象,條件調用Cursor對象的moveToNext()方法

循環中調用Cursor對象的getString()方法,傳入字段索引

關閉游標Cursor對象的close()方法

把得到的地址返回出去

拷貝數據庫從assets目錄到data目錄

在歡迎頁面,進行拷貝

調用getAssets().open()方法,得到InputStream對象,參數:xxx.db文件名

獲取File對象,new出來,參數:getFilesDir()獲取到/data/data/包/files/目錄,xxx.db

獲取FileOutputStream對象,new出來,參數:File對象

定義緩沖區byte[] buffer,一般1024

定義長度len

while循環讀取,條件:讀入的長度不為-1

循環中調用FileOutputStream對象的write()方法,參數:緩沖區,從0開始,len長度

調用InputStream對象的close()方法

判斷只要存在和長度大于0就不再拷貝了,調用File對象的exist()方法和length()方法大于0

NumberQueryAddressUtil.java

package com.qingguow.mobilesafe.utils;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;public class NumberQueryAddressUtil {private static final String path = "/data/data/com.qingguow.mobilesafe/files/address.db";/*** 查詢號碼歸屬地* @param phone* @return*/public static String queryAddress(String phone){SQLiteDatabase db=SQLiteDatabase.openDatabase(path, null,SQLiteDatabase.OPEN_READONLY);Cursor cursor=db.rawQuery("select location from data2 where id=(select outkey from data1 where id=?)", new String[]{phone.substring(0,7)});while(cursor.moveToNext()){String address=cursor.getString(0);return address;}cursor.close();return "";}} 

拷貝數據庫

private void copyAddressDatabase() {try {//判斷是否存在File file = new File(getFilesDir(), "address.db");if (file.exists() && file.length() > 0) {return;}InputStream is = getAssets().open("address.db");FileOutputStream fos = new FileOutputStream(file);byte[] buffer = new byte[1024];int len = 0;while ((len = is.read(buffer)) != -1) {fos.write(buffer, 0, len);}is.close();fos.close();} catch (Exception e) {e.printStackTrace();}}

推薦閱讀:

淺析Android手機衛士sim卡綁定

深入淺析Android手機衛士保存密碼時進行md5加密

詳解Android 手機衛士設置向導頁面

淺析Android手機衛士關閉自動更新

淺析Android手機衛士自定義控件的屬性

淺析Android手機衛士讀取聯系人

淺析Android手機衛士接收短信指令執行相應操作

淺析Android手機衛士手機定位的原理

淺析Android手機衛士之手機實現短信指令獲取位置

以上內容是小編給大家介紹的Android手機衛士之號碼歸屬地查詢的相關內容,希望對大家有所幫助!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿拉善盟| 昌江| 宝兴县| 洪洞县| 玛沁县| 衡南县| 嵩明县| 阿城市| 大足县| 石城县| 成安县| 丁青县| 乐业县| 额尔古纳市| 安福县| 咸宁市| 新宁县| 岑巩县| 腾冲县| 双江| 望江县| 渭南市| 安泽县| 威海市| 白河县| 西峡县| 鹤岗市| 通江县| 炉霍县| 诏安县| 东方市| 永丰县| 池州市| 巴中市| 兴隆县| 长宁县| 中牟县| 涟水县| 方山县| 微山县| 济源市|