一、创建数据库:
主布局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>
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>
<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);
}
}
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);
}
}