SQLiteOutsideDB

本文介绍了一种在Android应用中从assets目录导入外部SQLite数据库的方法,并演示了如何使用该数据库查询电话号码对应的地理位置信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//将要导入的外部数据库,放在了assets包下
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends Activity {

    private EditText et_phone;
    private Button btnFind;
    private TextView tvLocal;
    private SQLiteDatabase db;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        loadInOutsideDB();
        db = openOrCreateDatabase(Environment.getExternalStorageDirectory()+"/mobilelocationCopy.db", MODE_PRIVATE, null);
       
        initView();
        btnFind.setOnClickListener(new OnClickListener() {
            
            @Override
            public void onClick(View v) {
                String phone = et_phone.getText().toString().trim();
                Cursor cursor = db.query("location_date",  null, "number = ?", new String[]{phone}, null, null, null);
                String string="";
                while (cursor.moveToNext()) {
                    string = cursor.getString(cursor.getColumnIndex("location"));
                }
                tvLocal.setText("归属地 : "+string);
            }
        });
        
    }

    private void initView() {
        et_phone = (EditText) findViewById(R.id.et_phone);
        btnFind = (Button) findViewById(R.id.btnFind);
        tvLocal = (TextView) findViewById(R.id.tvLocal);
    }
    @SuppressWarnings("resource")
    public void loadInOutsideDB(){
        try {
            InputStream is = getAssets().open("mobilelocation.db");
            File file = new File(Environment.getExternalStorageDirectory(),"mobilelocationCopy.db");
            FileOutputStream os = new FileOutputStream(file);
            byte[] buffer=new byte[1024];
            int length=0;
            while ((length=is.read(buffer))!=-1) {
                os.write(buffer, 0, length);
            }
            is.close();
            os.close();
        } catch (Exception e) {
            e.printStackTrace();
            
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SuperMonsterH

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值