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. FreeMarker语法知识

    FreeMarker的模板文件并不比HTML页面复杂多少,FreeMarker模板文件主要由如下4个部分组成:1,文本:直接输出的部分2,注释:<#-- ... -->格式部分,不会输出3 ...

  2. springMVC spring hibernate pom.xml备份

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  3. activity退出

    这里介绍两种方法:一种把每个activity记住,然后逐一干掉:另一种思路是使用广播.本文来源于网络,如有雷同,那是必须的.写此贴只是为了总结一下常用东东,还望原作者莫怪,本人真不是想侵权. 方法一. ...

  4. namespace用法

    1.在WCF.Controller中定义了一个UserModel,标记为① 2.在WCF.Controller.Model中定义了一个UserModel(同上,namespace不同),标记为② 3. ...

  5. 在iis中注册.net framework

    首先定位到文件夹:cd C:\Windows\Microsoft.NET\Framework\v4.0.30319 执行命令:aspnet_regiis.exe -i

  6. Ogre参考手册(五)3.2 合成器

    3.2 合成器Compositor 合成器框架是Ogre用于全屏后处理的API.你可以通过脚本而不是API定义合成器.你可以很容易为视口实例化合成器. 合成器基础 无论是要替换还是要与主渲染窗口混合, ...

  7. Win2D 官方文章系列翻译 - 处理设备丢失

    本文为个人博客备份文章,原文地址: http://validvoid.net/win2d-handling-device-lost/ “设备丢失”是指 GPU 设备失效无法继续进行渲染的情况.GPU ...

  8. 在Service Fabric上部署Java应用,体验一把微服务的自动切换

    虽然Service Fabric的Java支持版本还没有正式发布,但是Service Fabric本身的服务管理.部署.升级等功能是非常好用的,那么Java的开发者可以如何利用上Service Fab ...

  9. 【练习】显示MySQLadmin 库户籍选项

    [oracle@enmo ~]$ mysqladmin -V mysqladmin Ver , for Linux on x86_64

  10. Spring缓存注解@Cache使用

    参考资料 http://www.ibm.com/developerworks/cn/opensource/os-cn-spring-cache/ http://swiftlet.net/archive ...