• 实验八 sqlite数据库操作


    实验报告

    课程名称

    基于Android平台移动互联网开发

    实验日期

    2016年5月3日

    实验项目名称

    SQLite数据库操作

    实验地点

    S30010

    实验类型

    □验证型    √设计型    □综合型

    学  时

    2

    一、实验目的及要求(本实验所涉及并要求掌握的知识点)

    1.目的:设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面。

    2.要求:程序主界面是通讯录的目录显示手机上联系人的名称。点击联系人的姓名可以显示联系人的详细信息。在按了MEMU键之后会弹出菜单栏。单击菜单栏上的按钮可以添加联系人和删除联系人

     

    二、实验环境(本实验所使用的硬件设备和相关软件)

    (1)PC机

    (2)操作系统:Windows XP

    (3)软件: Eclipse, JDK1.6,Android SDK,ADT

    三、实验内容及步骤

    1)在res/drawable-mdpi目录下拷入程序要用的图标

    2)定义字符串资源string.xml

    3)开发布局文件activity_main.xml用于显示联系人列表。

    4)layout目录下新建一个detail.xml,用于显示联系人详细信息

    5)接下来便进入MainActivity端的开发,实现数据库增加、删除、修改记录等操作

    四、实验结果(本实验源程序清单及运行结果或实验结论、实验设计图)

    代码:

    mainActivity.java的代码:

    package com.example.sql;

     

    import java.util.ArrayList;

    import java.util.HashMap;

    import java.util.List;

    import java.util.Map;

     

     

     

    import android.os.Bundle;

    import android.printservice.PrintService;

    import android.app.Activity;

    import android.content.Intent;

    import android.database.Cursor;

    import android.database.sqlite.SQLiteDatabase;

    import android.graphics.Color;

    import android.util.Log;

    import android.view.Menu;

    import android.view.View;

    import android.view.View.OnClickListener;

    import android.view.View.OnCreateContextMenuListener;

    import android.widget.AdapterView;

    import android.widget.AdapterView.OnItemClickListener;

    import android.widget.AdapterView.OnItemLongClickListener;

    import android.widget.Button;

    import android.widget.ListView;

    import android.widget.SimpleAdapter;

    import android.widget.TextView;

    import android.widget.Toast;

     

    public class MainActivity extends Activity {

        Button add,delete;

        ListView list;

        MyOpenHelper dbhelper;

        SQLiteDatabase db;

        String s;

       

       

        @Override

        protected void onCreate(Bundle savedInstanceState) {

            super.onCreate(savedInstanceState);

            setContentView(R.layout.activity_main);

            Log.i("kdsjflkasjdklfas", "daskfjaklsjfdklsaf");

            add=(Button)findViewById(R.id.button1);

            delete=(Button)findViewById(R.id.button2);

            list=(ListView)findViewById(R.id.listView1);

           Log.i("kdsjflkasjdklfas", "daskfjaklsjfdklsaf");

           dbhelper=new MyOpenHelper(MainActivity.this, "personal_contacts.db",null,1);

           db=dbhelper.getReadableDatabase();

          

            Cursor c=db.rawQuery("select * from contacts", null);

            inflateList(c);

              

               

               

     

               list.setOnItemClickListener(new OnItemClickListener() {

     

                  @Override

                  public void onItemClick(AdapterView<?> arg0, View view,

                         int arg2, long arg3) {

                      // TODO Auto-generated method stub

                      view.setBackgroundColor(Color.BLUE);

                      TextView textview=(TextView)view.findViewById(R.id.textView1);

                       s = textview.getText().toString();

                     

                  }

               });

               list.setOnItemLongClickListener(new OnItemLongClickListener() {

     

                  @Override

                  public boolean onItemLongClick(AdapterView<?> arg0, View view,

                         int arg2, long arg3) {

                      // TODO Auto-generated method stub

                      view.setBackgroundColor(Color.BLUE);

    //                TextView textview=(TextView)view.findViewById(R.id.textView1);

    //                s = textview.getText().toString();

                      Intent intent1=new Intent(MainActivity.this,result.class);

                      startActivity(intent1);

                      finish();

                      return false;

                  }

               });

              

              

               add.setOnClickListener(new OnClickListener() {

                 

                  @Override

                  public void onClick(View arg0) {

                      // TODO Auto-generated method stub

                      Intent intent=new Intent(MainActivity.this,result.class);

                      startActivity(intent);

                      finish();

                  }

               });

              

               delete.setOnClickListener(new OnClickListener() {

                 

                  @Override

                  public void onClick(View arg0) {

                      // TODO Auto-generated method stub

                      db.delete("contacts", "name=?", new String[]{s});

                      Toast.makeText(MainActivity.this, "删除成功", Toast.LENGTH_LONG).show();

                      Cursor c=db.rawQuery("select * from contacts", null);

                      inflateList(c);

                  }

               });

               list.setOnItemClickListener(new OnItemClickListener() {

     

                  @Override

                  public void onItemClick(AdapterView<?> arg0, View view,

                         int arg2, long arg3) {

                      // TODO Auto-generated method stub

                      view.setBackgroundColor(Color.BLUE);

                      TextView textview=(TextView)view.findViewById(R.id.textView1);

                       s = textview.getText().toString();

                     

                  }

               });

              

       

           }

    private void inflateList(Cursor c) {

           // TODO Auto-generated method stub

           int count=c.getCount();

           String[] name=new String[count];

           int b=0;

           while(c.moveToNext()){

               name[b]=c.getString(c.getColumnIndex("name"));

               b++;

           }

           ArrayList<HashMap<String, Object>> listitem=new ArrayList<HashMap<String,Object>>();

           for(int i=0;i<count;i++){

               HashMap<String,Object> map=new HashMap<String, Object>();

               map.put("ItemTitle", "name[i]");

               Log.i("jakfaksjflaksjfl", "skajfklajslkfj");

               listitem.add(map);

               SimpleAdapter m=new SimpleAdapter(MainActivity.this, listitem, R.layout.item, new String[]{"ItemTitle"}, new int[]{R.id.ItemTitle});

               list.setAdapter(m);

           @Override

        public boolean onCreateOptionsMenu(Menu menu) {

            // Inflate the menu; this adds items to the action bar if it is present.

            getMenuInflater().inflate(R.menu.main, menu);

            return true;

        }

       

    }

    运行结果:(截图)

    1. sql项目效果图:

     

    五、实验总结(对本实验结果进行分析,实验心得体会及改进意见)

    对于这次的实验,我感觉有点难度,因为思路不是很清晰,所以实验并没有成功,虽然可以成功的添加数据,但是并不能让数据显示在listView上,不过虽然失败了,但是还是有所收获,我会继续寻找解决的方法。

    实验评语

     

    实验成绩

     

    指导教师签名:              年   月   日

               
  • 相关阅读:
    10 个十分难得的 javascript 开发经验
    牛人推荐的跨浏览器兼容性总结
    不可不看!CSS3中三十一种选择器用法
    jQuery制作鼠标经过显示图片大图,生成图片tips效果
    解决IE6中 PNG图片透明的终极方案-八种方案!
    关于JavaScript代码的执行效率总结
    【我们开发有力量之二】利用javascript制作批量网络投票机器人(自动改IP)
    网页制作中最有用的免费Ajax和JavaScript代码库
    纯javascript代码实现浏览器图片选择预览、旋转、批量上传
    悲催的IE6 七宗罪大吐槽(带解决方法)第二部分
  • 原文地址:https://www.cnblogs.com/xy1015/p/5484385.html
Copyright © 2020-2023  润新知