栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android+SQLite数据库实现的生词记事本功能实例

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android+SQLite数据库实现的生词记事本功能实例

本文实例讲述了Android+SQLite数据库实现的生词记事本功能。分享给大家供大家参考,具体如下:

主activity命名为

Dict:

代码如下:

package example.com.myapplication;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
public class Dict extends Activity
{
  MyDatabaseHelper dbHelper;
  Button insert = null;
  Button search = null;
  @Override
  public void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    // 创建MyDatabaseHelper对象,指定数据库版本为1,此处使用相对路径即可,
    // 数据库文件自动会保存在程序的数据文件夹的databases目录下。
    dbHelper = new MyDatabaseHelper(this
 , "myDict.db3" , 1);
    insert = (Button)findViewById(R.id.insert);
    search = (Button)findViewById(R.id.search);
    insert.setonClickListener(new View.onClickListener()
    {
      @Override
      public void onClick(View source)
      {
 //获取用户输入
 String word = ((EditText)findViewById(R.id.word))
     .getText().toString();
 String detail = ((EditText)findViewById(R.id.detail))
     .getText().toString();
 //插入生词记录
 insertData(dbHelper.getReadableDatabase() , word , detail);
 //显示提示信息
 Toast.makeText(Dict.this, "添加生词成功!" , Toast.LENGTH_SHORT)
     .show();
      }
    });
    search.setonClickListener(new View.onClickListener()
    {
      @Override
      public void onClick(View source)
      {
 // 获取用户输入
 String key = ((EditText) findViewById(R.id.key)).getText()
     .toString();
 // 执行查询
 Cursor cursor = dbHelper.getReadableDatabase().rawQuery(
     "select * from dict where word like ? or detail like ?",
     new String[]{"%" + key + "%" , "%" + key + "%"});
 //创建一个Bundle对象
 Bundle data = new Bundle();
 data.putSerializable("data", converCursorToList(cursor));
 //创建一个Intent
 Intent intent = new Intent(Dict.this
     , ResultActivity.class);
 intent.putExtras(data);
 //启动Activity
 startActivity(intent);
      }
    });
  }
  protected ArrayList>
  converCursorToList(Cursor cursor)
  {
    ArrayList> result =
      new ArrayList>();
    //遍历Cursor结果集
    while(cursor.moveTonext())
    {
      //将结果集中的数据存入ArrayList中
      Map map = new
   HashMap();
      //取出查询记录中第2列、第3列的值
      map.put("word" , cursor.getString(1));
      map.put("detail" , cursor.getString(2));
      result.add(map);
    }
    return result;
  }
  private void insertData(SQLiteDatabase db
      , String word , String detail)
  {
    //执行插入语句
    db.execSQL("insert into dict values(null , ? , ?)"
 , new String[]{word , detail});
  }
  @Override
  public void onDestroy()
  {
    super.onDestroy();
    //退出程序时关闭MyDatabaseHelper里的SQLiteDatabase
    if (dbHelper != null)
    {
      dbHelper.close();
    }
  }
}

他的布局文件activity_main代码如下:



  
  
  

另一个需要跳转的activity命名为:

ResultActivity

具体代码如下:

package example.com.myapplication;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import java.util.List;
import java.util.Map;
public class ResultActivity extends Activity
{
  @Override
  public void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.popup);
    ListView listView = (ListView)findViewById(R.id.show);
    Intent intent = getIntent();
    //获取该intent所携带的数据
    Bundle data = intent.getExtras();
    //从Bundle数据包中取出数据
    @SuppressWarnings("unchecked")
    List> list =
      (List>)data.getSerializable("data");
    //将List封装成SimpleAdapter
    SimpleAdapter adapter = new SimpleAdapter(
 ResultActivity.this , list
 , R.layout.ine , new String[]{"word" , "detail"}
 , new int[]{R.id.my_title , R.id.my_content});
    //填充ListView
    listView.setAdapter(adapter);
  }
}

他的布局文件命名为popup: 代码如下:



  
  


listView的子项目布局命名为ine:

代码如下:



  
  


最后数据库帮助类命名为:

MyDatabaseHelper:

代码如下:

package example.com.myapplication;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class MyDatabaseHelper extends SQLiteOpenHelper
{
  final String CREATE_TABLE_SQL =
      "create table dict(_id integer primary key autoincrement , word , detail)";
  public MyDatabaseHelper(Context context, String name, int version)
  {
    super(context, name, null, version);
  }
  @Override
  public void onCreate(SQLiteDatabase db)
  {
    // 第一个使用数据库时自动建表
    db.execSQL(CREATE_TABLE_SQL);
  }
  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
  {
    System.out.println("--------onUpdate Called--------"
 + oldVersion + "--->" + newVersion);
  }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作SQLite数据库技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/157753.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号