Android菜鸟成长记12 -- ORMLite的简单使用

Posted 土豆冰淇淋

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android菜鸟成长记12 -- ORMLite的简单使用相关的知识,希望对你有一定的参考价值。

  在我们的开发中,为了提高开发效率,我们一般都会使用到框架,ormilte则是我们必不可少的数据库框架。

  对于ORMLite我也是今天才刚刚接触,我们先从一个简单的项目来了解它吧。

ORMLite jar

  要想使用ormlite,我们要先下载其jar包。

  下载方法:

    我们可以到官网去下载:http://ormlite.com/releases/

    下载的时候,我们要下载一个core的jar和android的jar,本人用的是ormlite-android-5.0.jar和ormlite-core-5.0.jar

     然后把我们下载好的jar放在我项目中的lib下,然后加载到项目中即可

   

编写Bean类

 1 package com.example.bean;
 2 
 3 import com.j256.ormlite.field.DatabaseField;
 4 import com.j256.ormlite.table.DatabaseTable;
 5 
 6 @DatabaseTable(tableName="t_student")
 7 public class student {
 8 
 9     //generatedId表示该字段名为主键,却自增长
10     @DatabaseField(generatedId=true)
11     private int stuId;
12     @DatabaseField(columnName="stuName")
13     private String stuName;
14     @DatabaseField(columnName="age")
15     private int age;
16     public int getStuId() {
17         return stuId;
18     }
19     public void setStuId(int stuId) {
20         this.stuId = stuId;
21     }
22     public String getStuName() {
23         return stuName;
24     }
25     public void setStuName(String stuName) {
26         this.stuName = stuName;
27     }
28     public int getAge() {
29         return age;
30     }
31     public void setAge(int age) {
32         this.age = age;
33     }
34     
35 }



 @DatabaseTable(tableName = "tb_user"),标明这是数据库中的一张表

@DatabaseField(columnName = "name") ,columnName的值为该字段在数据中的列名

@DatabaseField(generatedId = true) ,generatedId 表示id为主键且自动生成

编写ORMilte的dao包

 

package com.example.ormlitetest;

import java.sql.SQLException;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.util.Log;

import com.example.bean.student;
import com.j256.ormlite.android.apptools.OrmLiteSqliteOpenHelper;
import com.j256.ormlite.dao.Dao;
import com.j256.ormlite.support.ConnectionSource;
import com.j256.ormlite.table.TableUtils;

public class DataBaseHelp extends OrmLiteSqliteOpenHelper{

    private static final int version = 1;
    private static final String DB_NAME = "text_data.db";
    //每张表对应一个
    private Dao<student,Integer> studao ;
    
    public Dao<student,Integer> getDao() throws SQLException{
        if(studao == null){
            studao = getDao(student.class);
        }
        return studao;
    }
    
    public DataBaseHelp(Context context) {
        super(context, DB_NAME, null, version);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase db, ConnectionSource connectionSource) {
        try {
            TableUtils.createTable(connectionSource, student.class);
            Log.i("tag", "创建数据库success");
        } catch (Exception e) {
            Log.i("tag", "错误");
        }
        
    }

    @Override
    public void onUpgrade(SQLiteDatabase arg0, ConnectionSource arg1, int arg2,
            int arg3) {
        // TODO Auto-generated method stub
        
    }
    
    
    @Override
    public void close() {
        // TODO Auto-generated method stub
        super.close();
        studao = null;
    }

}

这里我们需要继承OrmLiteSqliteOpenHelper,其实就是间接继承了SQLiteOpenHelper

然后需要实现两个方法:

1、onCreate(SQLiteDatabase database,ConnectionSource connectionSource)

创建表,我们直接使用ormlite提供的TableUtils.createTable(connectionSource, User.class);进行创建~

2、onUpgrade(SQLiteDatabase database, ConnectionSource connectionSource, int oldVersion, int newVersion)

更新表,使用ormlite提供的TableUtils.dropTable(connectionSource, User.class, true);进行删除操作~

删除完成后,别忘了,创建操作:onCreate(database, connectionSource);

MainActivity类通用数据库

  1 package com.example.ormlitetest;
  2 
  3 import java.sql.SQLException;
  4 import java.util.*;
  5 
  6 import com.example.bean.student;
  7 
  8 import android.app.Activity;
  9 import android.database.sqlite.SQLiteDatabase;
 10 import android.os.Bundle;
 11 import android.util.Log;
 12 import android.view.LayoutInflater;
 13 import android.view.View;
 14 import android.view.ViewGroup;
 15 import android.widget.BaseAdapter;
 16 import android.widget.ListView;
 17 import android.widget.TextView;
 18 
 19 public class MainActivity extends Activity {
 20 
 21     
 22     private SQLiteDatabase db;
 23     private ListView lv;
 24     private List<student> stulist = new ArrayList<student>();
 25 
 26     @Override
 27     protected void onCreate(Bundle savedInstanceState) {
 28         super.onCreate(savedInstanceState);
 29         setContentView(R.layout.activity_main);
 30 
 31         DataBaseHelp help = new DataBaseHelp(MainActivity.this);
 32         
 33         for (int i = 0; i < 100; i++) {
 34             student s = new student();
 35             s.setStuName("好无聊" + i);
 36             s.setAge(i);
 37             try {
 38                 help.getDao().create(s);
 39             } catch (SQLException e) {
 40                 // TODO Auto-generated catch block
 41                 e.printStackTrace();
 42             }
 43         }
 44         try {
 45             stulist = help.getDao().queryForAll();
 46         } catch (SQLException e) {
 47             // TODO Auto-generated catch block
 48             e.printStackTrace();
 49         }
 50         lv = (ListView) findViewById(R.id.listView1);
 51         lv.setAdapter(new BaseAdapter() {
 52 
 53             public View getView(int position, View convertView, ViewGroup parent) {
 54                 View view = null;
 55                 if (convertView == null) {
 56                     Log.i("info:", "没有缓存,重新生成" + position);
 57                     LayoutInflater inflater = MainActivity.this
 58                             .getLayoutInflater();
 59                     // 因为getView()返回的对象,adapter会自动赋给ListView
 60                     view = inflater
 61                             .inflate(R.layout.list_item, null);
 62                 } else {
 63                     Log.i("info:", "有缓存,不需要重新生成" + position);
 64                     view = convertView;
 65                 }
 66                 student s = stulist.get(position);
 67 
 68                 TextView tv_userName = (TextView) view
 69                         .findViewById(R.id.tv_stuName);
 70                 tv_userName.setText(s.getStuName());
 71                 tv_userName.setTextSize(15);
 72 
 73                 TextView tv_lastMessage = (TextView) view
 74                         .findViewById(R.id.tv_age);
 75                 tv_lastMessage.setText(s.getAge()+"");
 76                 tv_lastMessage.setTextSize(12);
 77 
 78                 return view;
 79             }
 80 
 81             @Override
 82             public long getItemId(int arg0) {
 83                 // TODO Auto-generated method stub
 84                 return 0;
 85             }
 86 
 87             @Override
 88             public Object getItem(int arg0) {
 89                 // TODO Auto-generated method stub
 90                 return null;
 91             }
 92 
 93             @Override
 94             public int getCount() {
 95                 // TODO Auto-generated method stub
 96                 return stulist.size();
 97             }
 98         });
 99         help.close();
100     }
101 
102 }

然后我们运行一下程序看一下

好了, 这就是本人对于ORMLite的初步了解。

以上是关于Android菜鸟成长记12 -- ORMLite的简单使用的主要内容,如果未能解决你的问题,请参考以下文章

Android菜鸟成长记5-ADB和sqllite

Android菜鸟成长记1 -- JSON的解析

Android菜鸟成长记8 -- 布局实践(微信界面的编写)

Android菜鸟成长记9 -- selector的用法

Android菜鸟成长记11 -- sqlite数据库的设计和升降级

菜鸟成长记