一、基础知识:

运用场景:

  1>应用运行需要保存一系列有一定关系有一定结构的数据(文本也可以但是存储效率低)

  2>文件类型:.db(一个数据库就是一个.db文件)

  3>路径:/data/data/projectPackage/databases/xxx.db

  4>默认其他应用不能访问

  5>应用卸载时会删除数据

SQLite:

  一款轻型关系数据库服务器,安装文件小(几百k,嵌入Android),支持多操作系统,支持多语言,处理速度快。

二、Android单元测试:

  1、测试类继承AndroidTestCase

  2、<!-- 使用安卓测试包application中 -->
        <uses-library android:name="android.test.runner"/>

  3、<!-- targetPackage的值与配置文件package值一致application外 -->
 <instrumentation android:name="android.test.InstrumentationTestRunner"
     android:targetPackage="com.example.testsqlite"/>

三、实用ListActivity优化功能:

  1、继承ListActivity

  2、布局文件中<ListView>的id必须为系统定义的id:list

  3、如果想在没有数据时显示一个提示文本,可在布局文件中定义一个<TextView>(id必须是 empty);

四、练习:

1、内容

使用SQLiteOpenHelper  、SQLiteDatabase、  Cursor对数据库进行操作;

使用ListView+BaseAdapter显示列表;

使用ContextMenu;

使用ListActivity.

2、一个功能的工作:

内存操作:集合/对象

存储操作:数据库/文件sp

界面操作:列表...。

3、数据库操作类

数据库帮助类

public class DBHelper extends SQLiteOpenHelper {

public DBHelper(Context context) {
  super(context, "xrk.db", null, 1);
 }

@Override
 public void onCreate(SQLiteDatabase db) {
  Log.i("TAG", "DBHelper onCreate");
  db.execSQL("create table black_number(_id integer primary key autoincrement,number varchar)");
 }

@Override
 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  // TODO Auto-generated method stub

}

}

数据库DAO

public class BlackNumberDao {

private DBHelper dbHelper;
 
 public BlackNumberDao(Context context) {
  
  dbHelper=new DBHelper(context);
 }
 
 /*
  * 添加一条记录
  * */
 public void add(BlackNumber blackNumber){
  //得到连接
  SQLiteDatabase database=dbHelper.getWritableDatabase();
  //执行insert
  ContentValues values=new ContentValues();
  values.put("number", blackNumber.getNumber());
  long id=database.insert("black_number", null, values);
  Log.i("TAG", "id="+id);
  //设置id
  blackNumber.setId((int) id);
  
  //关闭
  database.close();
 }
 
 /*
  * 根据id删除一条记录
  * */
 public void deleteById(int id){
  // 得到连接
  SQLiteDatabase database = dbHelper.getReadableDatabase();
  // 执行delete
  int deleteCount=database.delete("black_number", "_id=?",new String[]{id+""});
  // 关闭
  database.close();
 }
 
 /*
  *更新一条记录
  * */
 public void update(BlackNumber blackNumber){
  // 得到连接
  SQLiteDatabase database = dbHelper.getReadableDatabase();
  // 执行update
  ContentValues values=new ContentValues();
  values.put("number", blackNumber.getNumber());
  int updateCount=database.update("black_number", values, "_id="+blackNumber.getId(), null);
  // 关闭
  database.close();
 }
 
 /*查询所有记录  List<BlackNumber>
  * */
 public List<BlackNumber> getAll(){
  
  List<BlackNumber> list=new ArrayList<BlackNumber>();
  // 得到连接
  SQLiteDatabase database = dbHelper.getReadableDatabase();
  // 执行query
  Cursor cursor=database.query("black_number", null, null, null, null, null, "_id desc");
  while(cursor.moveToNext()){
   int id=cursor.getInt(0);
   String number=cursor.getString(1);
   list.add(new BlackNumber(id,number));
  }
  // 关闭
  cursor.close();
  database.close();
  return list;
 }
 
}

单元测试类

/*
 * 单元测试类
 * */
public class BlackNumberDaoTest extends AndroidTestCase {

public void testAdd(){
  //创建dao对象
  BlackNumberDao dao=new BlackNumberDao(getContext());
  //调用方法
  dao.add(new BlackNumber(-1,"456"));
  dao.add(new BlackNumber(-1,"123"));
 }
 
 public void testGetAll(){
  
  BlackNumberDao dao=new BlackNumberDao(getContext());
  List<BlackNumber> list=dao.getAll();
  Log.i("TAG", list.toString());
  
 }
}

控制类

public class MainActivity extends ListActivity {

private ListView lv_main;
 private BlackNumberAdapter adapter;
 private BlackNumberDao dao;
 private List<BlackNumber> data;
 int position;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
       
        lv_main=getListView();
        adapter=new BlackNumberAdapter();
        dao=new BlackNumberDao(this);
        data=dao.getAll();
        lv_main.setAdapter(adapter);
       
        //给ListView设置创建contextMenu的监听
        lv_main.setOnCreateContextMenuListener(this);
    }
   
    @Override
 public void onCreateContextMenu(ContextMenu menu, View v,
   ContextMenuInfo menuInfo) {
  super.onCreateContextMenu(menu, v, menuInfo);
  //添加item
  menu.add(0, 1, 0, "更新");
  menu.add(0, 2, 0, "删除");
  
  //得到长按的position
  AdapterContextMenuInfo info=(AdapterContextMenuInfo) menuInfo;
  position=info.position;
 }

@Override
    public boolean onContextItemSelected(MenuItem item) {
     
     //先根据position得到BlackNumber对象
     BlackNumber blackNumber=data.get(position);
     switch (item.getItemId()) {
  case 1://更新
   
   showUpdateDialog(blackNumber);
   break;
  case 2://删除
   dao.deleteById(blackNumber.getId());
   data.remove(position);
   adapter.notifyDataSetChanged();
   break;

default:
   break;
  }
     return super.onContextItemSelected(item);
    }

private void showUpdateDialog(final BlackNumber blackNumber) {
  
  final EditText editText=new EditText(this);
     editText.setHint(blackNumber.getNumber());
     new AlertDialog.Builder(this)
      .setTitle("添加黑名单")
      .setView(editText)
      .setPositiveButton("添加",new DialogInterface.OnClickListener() {
    
    @Override
    public void onClick(DialogInterface dialog, int which) {
     
     String newNumber=editText.getText().toString();
     blackNumber.setNumber(newNumber);
     dao.update(blackNumber);
     
     //通知更新列表
     adapter.notifyDataSetChanged();
    }
   })
      .setNegativeButton("取消", null)
      .show();
 }

public void add(View v){
     
     final EditText editText=new EditText(this);
     editText.setHint("输入黑名单好");
     new AlertDialog.Builder(this)
      .setTitle("添加黑名单")
      .setView(editText)
      .setPositiveButton("添加",new DialogInterface.OnClickListener() {
    
    @Override
    public void onClick(DialogInterface dialog, int which) {
     
     String number=editText.getText().toString();
     BlackNumber blackNumber=new BlackNumber(-1,number);
     dao.add(blackNumber);
     data.add(blackNumber);
     //通知更新列表
     adapter.notifyDataSetChanged();
    }
   })
      .setNegativeButton("取消", null)
      .show();
    }
   
   
   
    class BlackNumberAdapter extends BaseAdapter{

@Override
  public int getCount() {
   return data.size();
  }

@Override
  public Object getItem(int position) {
   return data.get(position);
  }

@Override
  public long getItemId(int position) {
   return 0;
  }

@Override
  public View getView(int position, View convertView, ViewGroup parent) {
   
   if (convertView==null) {
    convertView=View.inflate(MainActivity.this, android.R.layout.simple_list_item_1, null);
   }
   BlackNumber blackNumber=data.get(position);
   TextView textView=(TextView) convertView.findViewById(android.R.id.text1);
   textView.setText(blackNumber.getNumber());
   return convertView;
  }
  
     
    }
}

布局文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

<ListView
        android:id="@android:id/list"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1">
    </ListView>

<TextView
        android:id="@android:id/empty"
        android:layout_width="match_parent"
        android:gravity="center"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:text="还没有一个黑名单" />

<Button
        android:id="@+id/button1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="add"
        android:text="添加" />

</LinearLayout>

04-14 02:29