Ormlite 基本使用(关联表)(1)

/**

  • ArticleBean实体类,存储article数据表中的数据

  • 数据库中的article表和user表是关联的,因此我们需要在article表中配置外键

  • foreignColumnName:外键约束指向的类中的属性名

  • foreign:当前字段是否是外键

  • foreignAutoRefresh:如果这个属性设置为true,在关联查询的时候就不需要再调用refresh()方法了

*/

@DatabaseTable(tableName = “article”)

public class ArticleBean {

@DatabaseField(generatedId = true, columnName = “id”)

private int id;

@DatabaseField(columnName = “title”)

private String title;

@DatabaseField(columnName = “content”)

private String content;

@DatabaseField(columnName = “user_id”, foreign = true, foreignAutoRefresh = true, foreignAutoCreate = true,

foreignColumnName = UserBean.COLUMNNAME_ID)

private UserBean user_id;

public ArticleBean() {

}

public ArticleBean(String title, String content, UserBean user) {

this.title = title;

this.content = content;

this.user_id = user;

}

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getTitle() {

return title;

}

public void setTitle(String title) {

this.title = title;

}

public String getContent() {

return content;

}

public void setContent(String content) {

this.content = content;

}

public UserBean getUser() {

return user_id;

}

public void setUser(UserBean user) {

this.user_id = user;

}

@Override

public String toString() {

return “ArticleBean{” +

“id=” + id +

“, title='” + title + ‘’’ +

“, content='” + content + ‘’’ +

“, user=” + user_id +

‘}’;

}

}

  • 构建Bean对应的dao

UserDao:

import android.content.Context;

import com.j256.ormlite.dao.Dao;

import java.sql.SQLException;

import java.util.List;

import cn.tsou.ormlite.bean.UserBean;

import cn.tsou.ormlite.manager.DatabaseHelper;

/**

  • 操作User数据表的Dao类,封装这操作User表的所有操作

  • 通过DatabaseHelper类中的方法获取ORMLite内置的DAO类进行数据库中数据的操作

  • 调用dao的create()方法向表中添加数据

  • 调用dao的delete()方法删除表中的数据

  • 调用dao的update()方法修改表中的数据

  • 调用dao的queryForAll()方法查询表中的所有数据

*/

public class UserDao {

// ORMLite提供的DAO类对象,第一个泛型是要操作的数据表映射成的实体类;第二个泛型是这个实体类中ID的数据类型

private Dao<UserBean, Integer> dao;

public UserDao(Context context) {

try {

this.dao = DatabaseHelper.getInstance(context).getDao(UserBean.class);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 向user表中添加一条数据

public void insert(UserBean data) {

try {

dao.createIfNotExists(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 删除user表中的一条数据

public void delete(UserBean data) {

try {

dao.delete(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 修改user表中的一条数据

public void update(UserBean data) {

try {

dao.update(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 查询user表中的所有数据

public List queryAll() {

List users = null;

try {

users = dao.queryForAll();

} catch (SQLException e) {

e.printStackTrace();

}

return users;

}

// 根据ID取出用户信息

public UserBean queryById(int id) {

UserBean user = null;

try {

user = dao.queryForId(id);

} catch (SQLException e) {

e.printStackTrace();

}

return user;

}

}

ArticleDao:

import android.content.Context;

import com.j256.ormlite.dao.Dao;

import java.sql.SQLException;

import java.util.List;

import cn.tsou.ormlite.bean.ArticleBean;

import cn.tsou.ormlite.manager.DatabaseHelper;

/**

  • 操作article表的DAO类

*/

public class ArticleDao {

private Context context;

// ORMLite提供的DAO类对象,第一个泛型是要操作的数据表映射成的实体类;第二个泛型是这个实体类中ID的数据类型

private Dao<ArticleBean, Integer> dao;

public ArticleDao(Context context) {

this.context = context;

try {

this.dao = DatabaseHelper.getInstance(context).getDao(ArticleBean.class);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 添加数据

public void insert(ArticleBean data) {

try {

dao.create(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 删除数据

public void delete(ArticleBean data) {

try {

dao.delete(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 修改数据

public void update(ArticleBean data) {

try {

dao.update(data);

} catch (SQLException e) {

e.printStackTrace();

}

}

// 通过ID查询一条数据

public ArticleBean queryById(int id) {

ArticleBean article = null;

try {

article = dao.queryForId(id);

} catch (SQLException e) {

e.printStackTrace();

}

return article;

}

// 通过条件查询文章集合(通过用户ID查找)

public List queryByUserId(int user_id) {

try {

return dao.queryBuilder().where().eq(“id”, user_id).query();

} catch (SQLException e) {

e.printStackTrace();

}

return null;

}

}

  • 测试

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.util.Log;

import android.view.View;

import com.j256.ormlite.dao.ForeignCollection;

import java.util.Date;

import java.util.Iterator;

import java.util.List;

import cn.tsou.ormlite.bean.ArticleBean;

import cn.tsou.ormlite.bean.UserBean;

import cn.tsou.ormlite.dao.ArticleDao;

import cn.tsou.ormlite.dao.UserDao;

public class Main2Activity extends AppCompatActivity {

private UserDao userDao;

private ArticleDao articleDao;

private UserBean userData;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main2);

userDao = new UserDao(this);

articleDao = new ArticleDao(this);

}

/**

  • 添加一条数据

  • @param view

*/

public void add(View view) {

// 添加用户数据

userData = new UserBean(“张三1”, ‘1’, new Date(), “北京”);

userDao.insert(userData);

// 添加文章数据

ArticleBean articleData = new ArticleBean(“标题4”, “内容内容内容内容内容内容”, userData);

ArticleBean articleData1 = new ArticleBean(“标题5”, “内容内容内容内容内容内容”, userData);

ArticleBean articleData2 = new ArticleBean(“标题6”, “内容内容内容内容内容内容”, userData);

articleDao.insert(articleData1);

articleDao.insert(articleData2);

articleDao.insert(articleData);

}

/**

  • 添加子表一条数据

  • @param view

*/

public void add2(View view) {

UserBean userBean = userDao.queryById(1);

ArticleBean articleData = new ArticleBean(“标题新”, “内容内容内容内容内容内容新”, userBean);

ArticleBean articleData1 = new ArticleBean(“标题新1”, “内容内容内容内容内容内容新1”, userBean);

articleDao.insert(articleData);

articleDao.insert(articleData1);

}

/**

  • 删除

  • @param view

*/

public void delete(View view) {

UserBean userBean = userDao.queryById(1);

ForeignCollection articles = userBean.getArticles();

Iterator iterator = articles.iterator();

while (iterator.hasNext()) {

ArticleBean article = iterator.next();

articleDao.delete(article);

}

userDao.delete(userBean);

}

/**

  • 删除子表

  • @param view

*/

public void delete2(View view) {

articleDao.delete(articleDao.queryById(2));

}

/**

  • 更新

  • @param view

*/

public void updata(View view) {

UserBean userBean = userDao.queryById(1);

if (userBean == null) {

return;

}

userBean.setName(“我被更新啦”);

userDao.update(userBean);

}

/**

  • 更新子表

  • @param view

*/

public void updata2(View view) {

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • @param view

*/

public void updata2(View view) {

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-oqgRxoQw-1715743796106)]

[外链图片转存中…(img-5LMbmDjs-1715743796108)]

[外链图片转存中…(img-J8qss0JD-1715743796109)]

[外链图片转存中…(img-ZdzvhKsA-1715743796110)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值