sqlite数据库的基本增删改查操做

效果图示例android

 

 

 

一、在清单里添加相应的权限sql

 

 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>数据库

 

-----------------------------------------函数

 

 

二、在res文件夹下建立一个菜单文件夹menu工具

该菜单文件夹有2个菜单布局文件布局

add_menu.xml菜单布局文件.net

代码sqlite

 

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
   
    <item android:id="@+id/adddata_menu"
        android:title="添加学生信息"/>xml

</menu>blog

 

 

-------------------------

 

list_menu.xml菜单布局文件

 

代码

 

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/list_delete"
        android:title="删除"/>
    <item
        android:id="@+id/list_change"
        android:title="修改"/>
    <item
        android:id="@+id/list_no"
        android:title="不操做"/>

</menu>

 

======================


 

三、布局界面 -- 3个布局文件

1) activity_main.xml -- 只有一个ListView控件

2)item_activity.xml -- 有3个TextView 控件 用来显示 性别 年龄 分数

3)editdata_activity.xml -- 有3个EditText控件 用来添加 修改数据的编辑框

 

activity_main.xml布局文件

 

代码

 

<RelativeLayout 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"
    tools:context="${relativePackage}.${activityClass}" >

    <ListView
        android:id="@+id/listview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</RelativeLayout>

 

 

================================

 

 

item_activity.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="horizontal" >

    <TextView
        android:id="@+id/item_name"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="wrap_content"
        android:textSize="30sp"
        android:text="dddd"/>
   
     <TextView
        android:id="@+id/item_sex"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="wrap_content"
        android:textSize="30sp"
        android:text="dddd"/>
   
    
      <TextView
        android:id="@+id/item_age"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="wrap_content"
        android:textSize="30sp"
        android:text="dddd"/>
    

</LinearLayout>

 

 

=================================

 

editdata_activity.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" >

    <EditText
        android:id="@+id/edit_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="姓名"/>
   
     <EditText
        android:id="@+id/edit_sex"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="性别"/>
    
      <EditText
        android:id="@+id/edit_age"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="年龄"/>

</LinearLayout>

 

 

================================

 

四、有2个类 一个工具类 用来对数据库的增删改查的工做 一个MainActivity类

 

工具类

 

代码

 

public class Sqlite_operate_utils {
//File.separator -- 至关于  /
 private static String DB_PATH = Environment.getExternalStorageDirectory() + File.separator + "stuentinfo.db";
 private SQLiteDatabase db;
 
 //构造函数 new 该类的时候 就去找 须要找的 数据库
 public Sqlite_operate_utils() {
  db = SQLiteDatabase.openDatabase(DB_PATH, null, SQLiteDatabase.OPEN_READWRITE);
 }
 
 //查询 数据的 方法1
 public Cursor sqlite_select(String content, String[] condition){
  return db.rawQuery(content, condition);
 }
 
 //查询 数据 的 方法2
 public List<Map<String, String>> sqlite_selectlist(String content, String[] condition){
 // Log.i("data", "cursor:");
  Cursor cursor = db.rawQuery(content, condition);
  return cursorToList(cursor);
 }
 //返回List
 public List<Map<String, String>> cursorToList(Cursor cursor) {
  List<Map<String, String>> list = new ArrayList<Map<String,String>>();
  while(cursor.moveToNext()){//数据库表的 行
   Map<String, String> map = new HashMap<String, String>();
   for(int i = 0;i<cursor.getColumnCount();i++){//数据库表的列
    map.put(cursor.getColumnName(i), cursor.getString(i));
   }
   list.add(map);
  }
  cursor.close();
 // Log.i("data", "list:" + list.size());
  return list;
 }
 
 //增删改 的方法
 //返回布尔型 方便 查看 数据 操做 是否成功
 public boolean executeData(String execute_content, Object[] bindArgs){
  try {
   if(bindArgs == null){//要绑定占位符 的参数值
    db.execSQL(execute_content);
    return true;
   }else{
    db.execSQL(execute_content, bindArgs);
    return true;
   }
  } catch (SQLException e) {
   e.printStackTrace();
   return false;
  }
 }
 
 //关闭db
 public void destroy(){
  if(db != null){
   db.close();
  }
 }
}

============================

 

MainActivity 类

 

代码在  --  sqlite数据库的基本增删改查操做MainActivity类代码 

连接:http://my.oschina.net/u/2542711/blog/608649

相关文章
相关标签/搜索