QLite数据库的数据读取和写入 通过界面操作数据库

本教程详细介绍了如何在Android应用中使用SQLite数据库进行数据读取、写入及界面交互,包括创建数据库、操作数据和展示结果。

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

  • 1、SQLite数据库的数据读取和写入 

    2、创建扩展自SQLiteOpenHelper的类用于操作数据库,本课时讲解数据库的读取和写入方法,并将结果呈现在ListView当中。
    通过界面操作数据库在界面中实现数据的查找、插入、删除。
一、创建数据库:
  • package com.example.debug;


    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;


    public class Db extends SQLiteOpenHelper {


    public Db(Context context) {
    super(context, "db", null, 1);
    }


    @Override
    public void onCreate(SQLiteDatabase db) {
    String sql="CREATE TABLE USER(_id INTEGER PRIMARY KEY autoincrement ,name TEXT,sex TEXT)";
    db.execSQL(sql);
    }
    @Override
    public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
    // TODO Auto-generated method stub

    }


    }

主布局activity_main.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >
    
<ListView 
   android:id="@android:id/list"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:layout_weight="1"
   >    
</ListView>
<LinearLayout 
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   >
   <TextView 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Name:"
       />
   <EditText 
       android:id="@+id/etName"
      android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_weight="1"
       />
   
    <TextView 
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
        android:text="Sex:"
       />
   <EditText 
       android:id="@+id/etSex"
      android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_weight="1"
       />
    <Button
       android:id="@+id/btnadd"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="添加" />
</LinearLayout>
</LinearLayout>


分布局:user_list_cell.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >


    <TextView
        android:id="@+id/tvName"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="TextView" />


    <TextView
        android:id="@+id/tvSex"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="TextView" />


</LinearLayout>



Mainactivity.java:

package com.example.debug;


import java.io.File;


import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;


import android.os.Bundle;
import android.os.Environment;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.ListActivity;
import android.content.ContentValues;
import android.content.Context;
import android.content.DialogInterface;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;


import android.util.Log;
import android.view.Menu;
import android.view.View;


import android.widget.AdapterView;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
import android.widget.Toast;


public class MainActivity extends ListActivity{
private SimpleCursorAdapter adapter;
private EditText etName,etSex;
private Button btnadd;
private  Db db;
private SQLiteDatabase dbRead,dbWrite;
private OnItemLongClickListener listViewItemLongClickListener=new OnItemLongClickListener() {


@Override
public boolean onItemLongClick(AdapterView<?> parent, View view,
final int position, long id) {

new AlertDialog.Builder(MainActivity.this).setTitle("提醒").setMessage("您确定要删除吗").setNegativeButton("取消",null).setPositiveButton("确定", new DialogInterface.OnClickListener() {

@Override
public void onClick(DialogInterface arg0, int arg1) {
Cursor c=adapter.getCursor();
c.moveToPosition(position);
int itemId=c.getInt(c.getColumnIndex("_id"));
dbWrite.delete("user","_id=?", new String[]{itemId+""});
refreshListView();
}
}).show();

return true;
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
  //将数据放入到listview 
etName=(EditText) findViewById(R.id.etName);
etSex=(EditText) findViewById(R.id.etSex);

btnadd=(Button) findViewById(R.id.btnadd);
db=new Db(this);
dbRead=db.getReadableDatabase();
dbWrite=db.getWritableDatabase();
btnadd.setOnClickListener(new View.OnClickListener() {

@Override
public void onClick(View arg0) {
ContentValues cv=new ContentValues();
cv.put("name", etName.getText().toString());
cv.put("sex", etSex.getText().toString());
dbWrite.insert("user", null, cv);
refreshListView();
}
});
        adapter=new SimpleCursorAdapter(MainActivity.this, 
        R.layout.user_list_cell, 
        null, new String[]{"name","sex"}, 
        new int[]{R.id.tvName,R.id.tvSex});
        setListAdapter(adapter);
        refreshListView();
       

getListView().setOnItemLongClickListener(listViewItemLongClickListener);
        //写入数据
// SQLiteDatabase dbwrite=db.getWritableDatabase();
// ContentValues cv=new ContentValues();
// cv.put("name", "小高");
// cv.put("sex", "男");
// dbwrite.insert("user", null, cv);
//
// cv.put("name", "小张");
// cv.put("sex", "女");
// dbwrite.insert("user", null, cv);
//    dbwrite.close();
//从数据库中读入数据
// SQLiteDatabase dbRead=db.getReadableDatabase();
// Cursor c=dbRead.query("user", null, null, null, null, null, null);
// while(c.moveToNext()){
// String name=c.getString(c.getColumnIndex("name"));
// String sex=c.getString(c.getColumnIndex("sex"));
// Toast.makeText(MainActivity.this,String.format("name=%s,sex=%s",name,sex) , Toast.LENGTH_LONG).show();
// }
        
}
private void refreshListView(){
Cursor c=dbRead.query("user", null, null, null, null, null, null);
adapter.changeCursor(c);
}





}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值