关联表 ArticleBean
import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.table.DatabaseTable;
/**
-
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);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
![](https://i-blog.csdnimg.cn/blog_migrate/cc5e614923a8d2cc02eb94a0e8bf17d6.jpeg)
最后
总而言之,成功是留给准备好的人的。无论是参加什么面试,都要做好充足的准备,注意好面试的礼仪和穿着,向面试官表现出自己的热忱与真诚就好。即使最后没有过关,也要做好经验的总结,为下一次面试做好充足准备。
这里我为大家准备了一些我在面试后整理的面试专题资料,除了面试题,还总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料分享给大家,希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
毕竟不管遇到什么样的面试官,去面试首先最主要的就是自己的实力,只要实力够硬,技术够强,就不怕面试拿不到offer!
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
EF.jpg" />
最后
总而言之,成功是留给准备好的人的。无论是参加什么面试,都要做好充足的准备,注意好面试的礼仪和穿着,向面试官表现出自己的热忱与真诚就好。即使最后没有过关,也要做好经验的总结,为下一次面试做好充足准备。
这里我为大家准备了一些我在面试后整理的面试专题资料,除了面试题,还总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料分享给大家,希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
毕竟不管遇到什么样的面试官,去面试首先最主要的就是自己的实力,只要实力够硬,技术够强,就不怕面试拿不到offer!
[外链图片转存中…(img-T0eTVxGh-1711869828458)]
[外链图片转存中…(img-bNmfqp7s-1711869828458)]
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
[外链图片转存中…(img-xVJkcRR4-1711869828459)]