1、下载jar

具体到Android,需要在 http://ormlite.com/releases 页面下载两个jar 包(本文基于ORMLite的版本是:ormlite 4.49-SNAPSHOT):
(1)core列表下的jar包;
(2)android列表下的jar包。
如图所示:

将上面的两个jar包下载后放到Android工程项目中的libs包中,如图所示:

以上完成后,ORMLite开发环境搭建就完成了,接下来就可以使用了。

2、代码:

表student.java和AClass.java

 package com.zzw.ormlitedatabasetest;

 import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.table.DatabaseTable; @DatabaseTable(tableName = "Student")
public class Student { @DatabaseField(id = true, columnName = "Student_id")
public int Student_id;
@DatabaseField(columnName = "name")
public String name;
@DatabaseField(columnName = "sex")
public String sex;
@DatabaseField(columnName = "age")
public int age;
@DatabaseField(foreign = true, foreignAutoRefresh = true)
public AClass aClass; public Student() { } public Student(String name, String sex, int age) {
super();
this.name = name;
this.sex = sex;
this.age = age;
} @Override
public String toString() {
return "Student [Student_id=" + Student_id + ", name=" + name + ", sex=" + sex + ", age=" + age + ",className="
+ aClass.name + "]";
} }

Student

 package com.zzw.ormlitedatabasetest;

 import com.j256.ormlite.dao.ForeignCollection;
import com.j256.ormlite.field.DataType;
import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.field.ForeignCollectionField;
import com.j256.ormlite.table.DatabaseTable; @DatabaseTable(tableName = "Classess")
public class AClass { @DatabaseField(id = true, columnName = "classess_id")
public int classess_id;
@DatabaseField(dataType = DataType.STRING)
public String name;
@ForeignCollectionField(eager = false)
public ForeignCollection<Student> students = null; public AClass() {
super();
} public AClass(int classess_id, String name, ForeignCollection<Student> students) {
super();
this.classess_id = classess_id;
this.name = name;
this.students = students;
} }

AClass

ORMLite数据库管理工具类ORMLiteDatabaseHelper.java:

 package com.zzw.ormlitedatabasetest;

 import java.sql.SQLException;

 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; import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.util.Log; public class OrmLiteDatabaseHelper extends OrmLiteSqliteOpenHelper {
private static final String TAG = "OrmLiteDatabaseHelper"; public static OrmLiteDatabaseHelper mDatabaseHelper = null; public Dao<Student, Integer> mStudentDao = null;
public Dao<AClass, Integer> mAClassDao = null; public static String database_NAME = "school.db";
public static int database_VERSION = 1; public OrmLiteDatabaseHelper(Context context, String databaseName, CursorFactory factory, int databaseVersion) {
super(context, databaseName, factory, databaseVersion);
} public static OrmLiteDatabaseHelper getInstance(Context context) {
if (mDatabaseHelper == null) {
mDatabaseHelper = new OrmLiteDatabaseHelper(context, database_NAME, null, database_VERSION);
}
Log.d(TAG, "数据库school.db创建成功");
return mDatabaseHelper;
} @Override
public void onCreate(SQLiteDatabase arg0, ConnectionSource arg1) {
try {
TableUtils.createTableIfNotExists(arg1, AClass.class);
Log.e(TAG, "AClass表在School.db中被创建");
TableUtils.createTableIfNotExists(arg1, Student.class);
Log.e(TAG, "Student表在School.db中被创建");
} catch (SQLException e) {
e.printStackTrace();
} } @Override
public void onUpgrade(SQLiteDatabase arg0, ConnectionSource arg1, int arg2, int arg3) { } public Dao<Student, Integer> getStudentDao() {
if (mStudentDao == null) {
try {
mStudentDao = getDao(Student.class);
Log.e(TAG, "得到Student的Dao");
} catch (SQLException e) {
e.printStackTrace();
}
}
return mStudentDao;
} public Dao<AClass, Integer> getAClassDao() {
if (mAClassDao == null) {
try {
mAClassDao = getDao(AClass.class);
Log.e(TAG, "得到AClass的Dao");
} catch (SQLException e) {
e.printStackTrace();
}
}
return mAClassDao;
} @Override
public void close() {
super.close();
if (mAClassDao != null) {
mAClassDao = null;
}
if (mStudentDao != null) {
mStudentDao = null;
}
}
}

MainActivity:

 package com.zzw.ormlitedatabasetest;

 import java.sql.SQLException;
import java.util.List; import com.j256.ormlite.dao.Dao; import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.widget.ScrollView;
import android.widget.TextView;
import android.widget.Toast; public class MainActivity extends Activity { private static final String TAG = "MainActivity"; private Dao<AClass, Integer> mAClassDao = null;
private Dao<Student, Integer> mStudentDao = null; AClass aClass1, aClass2, aClass3, aClass4, aClass5; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); OrmLiteDatabaseHelper mOrmLiteDatabaseHelper = OrmLiteDatabaseHelper.getInstance(this); mAClassDao = mOrmLiteDatabaseHelper.getAClassDao();
mStudentDao = mOrmLiteDatabaseHelper.getStudentDao(); } @Override
protected void onStart() {
Log.d(TAG, ">>>>>>>>>>>>");
super.onStart();
int AClasses_count = createAClasses();
if (AClasses_count == 5) {
try {
aClass1 = mAClassDao.queryForId(1);
aClass2 = mAClassDao.queryForId(2);
aClass3 = mAClassDao.queryForId(3);
aClass4 = mAClassDao.queryForId(4);
aClass5 = mAClassDao.queryForId(5); createStudents(); } catch (Exception e) {
e.printStackTrace();
}
} else {
Toast.makeText(this, "班级创建错误", 0).show();
}
queryAllStudents();
} private void createStudents() {
Log.d(TAG, "学生创建开始------>");
Student student = new Student();
for (int i = 1; i <= 20; i++) {
student.Student_id = i;
student.age = (int) (Math.random() * 100);
if (i % 2 == 0) {
student.sex = "男";
} else {
student.sex = "女";
}
if (i > 0 && i <= 4) {
student.aClass = aClass1;
student.name = "陶" + i;
} else if (i > 4 && i <= 8) {
student.aClass = aClass2;
student.name = "李" + i;
} else if (i > 8 && i <= 12) {
student.aClass = aClass3;
student.name = "阿" + i;
} else if (i > 12 && i <= 16) {
student.aClass = aClass4;
student.name = "曾" + i;
} else {
student.aClass = aClass5;
student.name = "蒋" + i;
} try {
mStudentDao.createIfNotExists(student);
} catch (SQLException e) {
e.printStackTrace();
}
}
Log.d(TAG, "学生创建成功------>");
} private int createAClasses() {
Log.d(TAG, "班级创建开始------>");
AClass aClass = new AClass();
int AClasses_count = 0;
for (int i = 1; i <= 5; i++) {
aClass.classess_id = i;
aClass.name = "高三" + i + "班";
try {
mAClassDao.createIfNotExists(aClass);
AClasses_count++;
} catch (SQLException e) {
e.printStackTrace();
}
}
Log.d(TAG, "班级创建成功------>");
return AClasses_count;
} private void queryAllStudents() {
Log.d(TAG, "查询全部学生开始------>>>>");
try {
List<Student> students = mStudentDao.queryForAll();
if (students != null && students.size() > 0) {
for (Student student : students) {
Log.i(TAG, student.toString());
}
}
} catch (SQLException e) {
e.printStackTrace();
}
Log.d(TAG, "查询全部学生完毕------>>>>");
} @Override
protected void onDestroy() {
super.onDestroy();
if (mAClassDao != null) {
mAClassDao = null;
}
if (mStudentDao != null) {
mStudentDao = null;
}
Log.d(TAG, "<<<<<<<<<<<");
} }

ORMLiteDatabase的简单使用并且与其他的表相互联系的更多相关文章

  1. java 散列与散列码探讨 ,简单HashMap实现散列映射表运行各种操作示列

    java 散列与散列码探讨 ,简单HashMap实现散列映射表运行各种操作示列 package org.rui.collection2.maps; /** * 散列与散列码 * 将土拔鼠对象与预报对象 ...

  2. Hive数据导入——数据存储在Hadoop分布式文件系统中,往Hive表里面导入数据只是简单的将数据移动到表所在的目录中!

    转自:http://blog.csdn.net/lifuxiangcaohui/article/details/40588929 Hive是基于Hadoop分布式文件系统的,它的数据存储在Hadoop ...

  3. mysql常用基础操作语法(四)--对数据的简单无条件查询及库和表查询【命令行模式】

    1.mysql简单的查询:select 字段1,字段2...  from tablename; 如果字段那里写一个*,代表查询所有的字段,等同于指定出所有的字段名,因此如果要查询所有字段的数据,一般都 ...

  4. python3: 简单4步骤输出九九乘法表

    如何输出一个九九乘法表,使用python语言,嵌套循环,4行代码就可以实现,瞬间感觉python真的很简单~ 代码: for i in range(1,10): for j in range(1,i+ ...

  5. PL/SQL简单使用——导入、导出数据表

    1.使用PL/SQL导出.导入表 在使用PL/SQL操作oracle数据库时,经常使用的一个操作就是将自己写的数据表导出,或者想把他人的数据表导入到自己的数据库中.虽然是很简单的操作,但自己之前一直出 ...

  6. redis底层数据结构--简单动态字符串 链表 字典 跳跃表 整数集合 压缩列表

    1.动态字符串 redis中使用c语言的字符床存储字面量,默认字符串存储采用自己构建的简单动态字符串SDS(symple dynamic string) redis包含字符串的键值对都是用SDS实现的 ...

  7. Python基础总结之第六天开始【先简单认识一次函数】(新手可相互督促)

    午休后,看看电视,在回顾下新的知识----函数.相信很多小伙伴在学习python后 ,学到函数就会有一部分人放弃了,从努力到放弃(内容过于真实) 好希望我也能有很多粉丝,hhh.... 函数: 什么是 ...

  8. 写一个简单易用可扩展vue表单验证插件(vue-validate-easy)

    写一个vue表单验证插件(vue-validate-easy) 需求 目标:简单易用可扩展 如何简单 开发者要做的 写了一个表单,指定一个name,指定其验证规则. 调用提交表单方法,可以获取验证成功 ...

  9. 【redis】redis底层数据结构原理--简单动态字符串 链表 字典 跳跃表 整数集合 压缩列表等

    redis有五种数据类型string.list.hash.set.zset(字符串.哈希.列表.集合.有序集合)并且自实现了简单动态字符串.双端链表.字典.压缩列表.整数集合.跳跃表等数据结构.red ...

随机推荐

  1. Prevent Adding Component More than once

    Question: I'm developing a C# component, I want to prevent the user from adding this component to th ...

  2. Eclispe 安装PropertiesEditor插件

    一个不错的编写properties文件的Eclipse插件(plugin),有了它我们在编辑一些简体中文.繁体中文等Unicode文本时,就不必再使用native2ascii编码了.您可以通过Ecli ...

  3. H264 Profile

    H.264有四种profile,对应四种H264画质级别.每个profile支持一组特定的编码功能,并支持一类特定的应用,分别是BP.EP.MP.HP: 1. BP-Baseline Profile ...

  4. RequireJS API

    可以找到许多的解读,但是原文总是最重要的,也是最正宗的说明,直接访问 RequireJS 有时不太方便,这里将 RequireJS 2.0 API 的原文转载到博客园,方便查看. This is th ...

  5. win8或win8.1修改注册表失败的原因

    win8 and win8.1 modify the registry need compiled to be different versions according to the os bits.

  6. PERT(计划评审技术,Program Evaluation an Review Technique)

    如果你对项目管理.系统架构有兴趣,请加微信订阅号"softjg",加入这个PM.架构师的大家庭 PERT(计划评审技术,Program Evaluation an Review T ...

  7. ffmpeg视频格式转换(Java)

    命令: 高品质: ffmpeg -i E:\input\a.wmv -ab 128 -acodec libmp3lame -ac 1 -ar 22050 -r 29.97 -qscale 4 -y E ...

  8. Retina CS强大漏洞检测工具

    RetinaCS强大漏洞检测工具 Eeye数字安全公司成立于上世纪九十年代末期,它是世界领先的安全公司,它采用最新研究成果和创新技术来保证您的网络兄系统安全,并向您提供最强大的如下服务:全面的.漏洞评 ...

  9. Use BEC to do mobile phone forensics

    Belkasoft Evidence Center makes me very impressed that it supports lots of evidence type. I have to ...

  10. poj3349 哈希

    这题目写了一上午,一直错,然后自己测试数据还都对.为什么呢,为什么呢,后来我才发现代码里有一行free(tmp)...在55行那里... #include <stdio.h> #inclu ...