Android-使用ListView把SQLite中的数据显示至屏幕

结果图:



步骤:

1.向数据库中插入数据

2.从数据库中取出数据放在ArrayList中;

3.将ArrayList中的数据显示在ListView中;


布局文件:

activity_main.xml

[html]  view plain  copy
 print ?
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:paddingBottom="@dimen/activity_vertical_margin"  
  6.     android:paddingLeft="@dimen/activity_horizontal_margin"  
  7.     android:paddingRight="@dimen/activity_horizontal_margin"  
  8.     android:paddingTop="@dimen/activity_vertical_margin"  
  9.     tools:context="com.example.android04.MainActivity" >  
  10.   
  11.     <ListView  
  12.         android:id="@+id/listView"  
  13.         android:layout_width="wrap_content"  
  14.         android:layout_height="wrap_content" >  
  15.     </ListView>  
  16.   
  17. </RelativeLayout>  
listitem_layout.xml

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent" >  
  5.   
  6.     <TextView  
  7.         android:id="@+id/tv_name"  
  8.         android:layout_width="wrap_content"  
  9.         android:layout_height="wrap_content"  
  10.         android:text="名字"  
  11.         android:textSize="25sp" />  
  12.   
  13.     <LinearLayout  
  14.         android:layout_width="wrap_content"  
  15.         android:layout_height="wrap_content"  
  16.         android:layout_alignParentRight="true"  
  17.         android:orientation="vertical" >  
  18.         <TextView   
  19.             android:id="@+id/tv_phone"  
  20.         android:layout_width="wrap_content"  
  21.         android:layout_height="wrap_content"  
  22.         android:text="号码"  
  23.         />  
  24.         <TextView   
  25.             android:id="@+id/tv_salary"  
  26.             android:layout_width="wrap_content"  
  27.             android:layout_height="wrap_content"  
  28.             android:text="工资"  
  29.             />  
  30.     </LinearLayout>  
  31.   
  32. </RelativeLayout>  

Java文件:
Person.java

[java]  view plain  copy
 print ?
  1. package com.example.cn;  
  2.   
  3. public class Person {  
  4.   
  5.     private String _id;  
  6.     private String name;  
  7.     private String phone;  
  8.     private String salary;  
  9.       
  10.     public String get_id() {  
  11.         return _id;  
  12.     }  
  13.     public void set_id(String _id) {  
  14.         this._id = _id;  
  15.     }  
  16.     public String getName() {  
  17.         return name;  
  18.     }  
  19.     public void setName(String name) {  
  20.         this.name = name;  
  21.     }  
  22.     public String getPhone() {  
  23.         return phone;  
  24.     }  
  25.     public void setPhone(String phone) {  
  26.         this.phone = phone;  
  27.     }  
  28.     public String getSalary() {  
  29.         return salary;  
  30.     }  
  31.     public void setSalary(String salary) {  
  32.         this.salary = salary;  
  33.     }  
  34.     @Override  
  35.     public String toString() {  
  36.         return name + ", " + phone + ", " + salary;  
  37.     }  
  38.     public Person(String _id, String name, String phone, String salary) {  
  39.         super();  
  40.         this._id = _id;  
  41.         this.name = name;  
  42.         this.phone = phone;  
  43.         this.salary = salary;  
  44.     }  
  45.       
  46.       
  47. }  
MyOpenHelper.java

[java]  view plain  copy
 print ?
  1. package com.example.android04;  
  2.   
  3. import android.content.Context;  
  4. import android.database.sqlite.SQLiteDatabase;  
  5. import android.database.sqlite.SQLiteDatabase.CursorFactory;  
  6. import android.database.sqlite.SQLiteOpenHelper;  
  7.   
  8. public class MyOpenHelper extends SQLiteOpenHelper {  
  9.   
  10.     public MyOpenHelper(Context context) {  
  11.         //创建数据库  
  12.         super(context, "person.db"null1);  
  13.         // TODO Auto-generated constructor stub  
  14.         System.out.println("MyOpenHelper");  
  15.     }  
  16.   
  17.     @Override  
  18.     public void onCreate(SQLiteDatabase db) {  
  19.         // TODO Auto-generated method stub  
  20.         //创建表  
  21.         db.execSQL("create table person(_id integer primary key autoincrement, name char(10), salary char(20), phone integer(20) )");  
  22.   
  23.     }  
  24.   
  25.     @Override  
  26.     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
  27.         // TODO Auto-generated method stub  
  28.   
  29.     }  
  30.   
  31. }  

MainActivity.java

[java]  view plain  copy
 print ?
  1. package com.example.android04;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import android.app.Activity;  
  7. import android.content.ContentValues;  
  8. import android.content.Context;  
  9. import android.database.Cursor;  
  10. import android.database.sqlite.SQLiteDatabase;  
  11. import android.graphics.drawable.LayerDrawable;  
  12. import android.os.Bundle;  
  13. import android.view.LayoutInflater;  
  14. import android.view.View;  
  15. import android.view.ViewGroup;  
  16. import android.widget.BaseAdapter;  
  17. import android.widget.ListView;  
  18. import android.widget.TextView;  
  19.   
  20. import com.example.cn.Person;  
  21.   
  22. public class MainActivity extends Activity {  
  23.   
  24.     List<Person> personList;  
  25.     MyOpenHelper mOpenHelper;  
  26.     SQLiteDatabase db;  
  27.     MyAdapter myAdapter;  
  28.   
  29.     @Override  
  30.     protected void onCreate(Bundle savedInstanceState) {  
  31.         super.onCreate(savedInstanceState);  
  32.         setContentView(R.layout.activity_main);  
  33.         ListView lv = (ListView) findViewById(R.id.listView);  
  34.         personList = new ArrayList<Person>();  
  35.         // 创建MyOpenHelper实例  
  36.         mOpenHelper = new MyOpenHelper(this);  
  37.         // 得到数据库  
  38.         db = mOpenHelper.getWritableDatabase();  
  39.         // 插入数据  
  40.         Insert();  
  41.         // 查询数据  
  42.         Query();  
  43.         // 创建MyAdapter实例  
  44.         myAdapter = new MyAdapter(this);  
  45.         // 向listview中添加Adapter  
  46.         lv.setAdapter(myAdapter);  
  47.     }  
  48.   
  49.     // 创建MyAdapter继承BaseAdapter  
  50.     class MyAdapter extends BaseAdapter {  
  51.         private Context context;  
  52.         private LayoutInflater inflater;  
  53.   
  54.         public MyAdapter(Context context) {  
  55.             this.context = context;  
  56.             inflater = LayoutInflater.from(context);  
  57.         }  
  58.   
  59.         @Override  
  60.         public int getCount() {  
  61.             // TODO Auto-generated method stub  
  62.             return personList.size();  
  63.         }  
  64.   
  65.         @Override  
  66.         public Object getItem(int position) {  
  67.             // TODO Auto-generated method stub  
  68.             return null;  
  69.         }  
  70.   
  71.         @Override  
  72.         public long getItemId(int position) {  
  73.             // TODO Auto-generated method stub  
  74.             return 0;  
  75.         }  
  76.   
  77.         @Override  
  78.         public View getView(int position, View convertView, ViewGroup parent) {  
  79.             // 从personList取出Person  
  80.             Person p = personList.get(position);  
  81.             ViewHolder viewHolder = null;  
  82.             if (convertView == null) {  
  83.                 viewHolder = new ViewHolder();  
  84.                 convertView = inflater.inflate(R.layout.listitem_layout, null);  
  85.                 viewHolder.txt_name = (TextView) convertView  
  86.                         .findViewById(R.id.tv_name);  
  87.                 viewHolder.txt_phone = (TextView) convertView  
  88.                         .findViewById(R.id.tv_phone);  
  89.                 viewHolder.txt_salary = (TextView) convertView  
  90.                         .findViewById(R.id.tv_salary);  
  91.                 convertView.setTag(viewHolder);  
  92.             } else {  
  93.                 viewHolder = (ViewHolder) convertView.getTag();  
  94.             }  
  95.             //向TextView中插入数据  
  96.             viewHolder.txt_name.setText(p.getName());  
  97.             viewHolder.txt_phone.setText(p.getPhone());  
  98.             viewHolder.txt_salary.setText(p.getSalary());  
  99.   
  100.             return convertView;  
  101.         }  
  102.     }  
  103.   
  104.     class ViewHolder {  
  105.         private TextView txt_name;  
  106.         private TextView txt_phone;  
  107.         private TextView txt_salary;  
  108.     }  
  109.   
  110.     // 插入数据  
  111.     public void Insert() {  
  112.         for (int i = 0; i < 100; i++) {  
  113.             ContentValues values = new ContentValues();  
  114.             values.put("name""张三" + i);  
  115.             values.put("salary""123" + i + i);  
  116.             values.put("phone""151" + i + i);  
  117.             db.insert("person"null, values);  
  118.         }  
  119.     }  
  120.   
  121.     // 查询数据  
  122.     public void Query() {  
  123.         Cursor cursor = db.query("person"nullnullnullnullnullnull);  
  124.         while (cursor.moveToNext()) {  
  125.             String _id = cursor.getString(0);  
  126.             String name = cursor.getString(1);  
  127.             String salary = cursor.getString(2);  
  128.             String phone = cursor.getString(3);  
  129.             Person person = new Person(_id, name, phone, salary);  
  130.             personList.add(person);  
  131.         }  
  132.     }  
  133.   
  134. }  
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值