可能有人会直接在Article中声明一个int类型userId属性,当作普通属性处理搞定,这种做法并没有做,但是没有体现出面向对象的思想。
面向对象是这样的:Article属于某个User
类这么定义:
[java] view plain copy
-
package com.zhy.zhy_ormlite.bean;
-
import com.j256.ormlite.field.DatabaseField;
-
import com.j256.ormlite.table.DatabaseTable;
-
@DatabaseTable(tableName = “tb_article”)
-
public class Article
-
{
-
@DatabaseField(generatedId = true)
-
private int id;
-
@DatabaseField
-
private String title;
-
@DatabaseField(canBeNull = true, foreign = true, columnName = “user_id”)
-
private User 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 User getUser()
-
{
-
return user;
-
}
-
public void setUser(User user)
-
{
-
this.user = user;
-
}
-
@Override
-
public String toString()
-
{
-
return “Article [id=” + id + “, title=” + title + “, user=” + user
-
+ “]”;
-
}
-
}
不会去定义一个int类型的userId,而是直接定义一个User成员变量,表示本Article属于该User;
然后在User user属性上添加: @DatabaseField(canBeNull = true, foreign = true, columnName = “user_id”)
canBeNull -表示不能为null;foreign=true表示是一个外键;columnName 列名
User类暂且就两个属性:
[java] view plain copy
-
package com.zhy.zhy_ormlite.bean;
-
import com.j256.ormlite.field.DatabaseField;
-
import com.j256.ormlite.table.DatabaseTable;
-
@DatabaseTable(tableName = “tb_user”)
-
public class User
-
{
-
@DatabaseField(generatedId = true)
-
private int id;
-
@DatabaseField(columnName = “name”)
-
private String name;
-
public User()
-
{
-
}
-
public int getId()
-
{
-
return id;
-
}
-
public void setId(int id)
-
{
-
this.id = id;
-
}
-
public String getName()
-
{
-
return name;
-
}
-
public void setName(String name)
-
{
-
this.name = name;
-
}
-
@Override
-
public String toString()
-
{
-
return “User [id=” + id + “, name=” + name
-
+ “]”;
-
}
-
}
现在看我们的ArticleDao
[java] view plain copy
-
package com.zhy.zhy_ormlite.db;
-
import java.sql.SQLException;
-
import java.util.List;
-
import android.content.Context;
-
import com.j256.ormlite.dao.Dao;
-
import com.zhy.zhy_ormlite.bean.Article;
-
import com.zhy.zhy_ormlite.bean.User;
-
public class ArticleDao
-
{
-
private Dao<Article, Integer> articleDaoOpe;
-
private DatabaseHelper helper;
-
@SuppressWarnings(“unchecked”)
-
public ArticleDao(Context context)
-
{
-
try
-
{
-
helper = DatabaseHelper.getHelper(context);
-
articleDaoOpe = helper.getDao(Article.class);
-
} catch (SQLException e)
-
{
-
e.printStackTrace();
-
}
-
}
-
/**
-
* 添加一个Article
-
* @param article
-
*/
-
public void add(Article article)
-
{
-
try
-
{
-
articleDaoOpe.create(article);
-
} catch (SQLException e)
-
{
-
e.printStackTrace();
-
}
-
}
-
/**
-
* 通过Id得到一个Article
-
* @param id
-
* @return
-
*/
-
@SuppressWarnings(“unchecked”)
-
public Article getArticleWithUser(int id)
-
{
-
Article article = null;
-
try
-
{
-
article = articleDaoOpe.queryForId(id);
-
helper.getDao(User.class).refresh(article.getUser());
-
} catch (SQLException e)
-
{
-
e.printStackTrace();
-
}
-
return article;
-
}
-
/**
-
* 通过Id得到一篇文章
-
* @param id
-
* @return
-
*/
-
public Article get(int id)
-
{
-
Article article = null;
-
try
-
{
-
article = articleDaoOpe.queryForId(id);
-
} catch (SQLException e)
-
{
-
e.printStackTrace();
-
}
-
return article;
-
}
-
/**
-
* 通过UserId获取所有的文章
-
* @param userId
-
* @return
-
*/
-
public List
listByUserId(int userId) -
{
-
try
-
{
-
return articleDaoOpe.queryBuilder().where().eq(“user_id”, userId)
-
.query();
-
} catch (SQLException e)
-
{
-
e.printStackTrace();
-
}
-
return null;
-
}
-
}
接下来看我们的测试类:
[java] view plain copy
-
public class OrmLiteDbTest extends AndroidTestCase
-
{
-
public void testAddArticle()
-
{
-
User u = new User();
-
u.setName(“张鸿洋”);
-
new UserDao(getContext()).add(u);
-
Article article = new Article();
-
article.setTitle(“ORMLite的使用”);
-
article.setUser(u);
-
new ArticleDao(getContext()).add(article);
-
}
-
public void testGetArticleById()
-
{
-
Article article = new ArticleDao(getContext()).get(1);
-
L.e(article.getUser() + " , " + article.getTitle());
-
}
-
public void testGetArticleWithUser()
-
{
-
Article article = new ArticleDao(getContext()).getArticleWithUser(1);
-
L.e(article.getUser() + " , " + article.getTitle());
-
}
-
public void testListArticlesByUserId()
-
{
-
List
articles = new ArticleDao(getContext()).listByUserId(1); -
L.e(articles.toString());
-
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
最后
文章所有资料全部已经打包整理好,另外小编手头上整理了大量Android架构师全套学习资料,Android核心高级技术PDF文档+全套高级学习资料+视频+2021 BAT 大厂面试真题解析
资料展示:
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
示:**
[外链图片转存中…(img-HsxQGQKr-1712382550609)]
[外链图片转存中…(img-di69ZjaF-1712382550610)]
[外链图片转存中…(img-Rd1W15uf-1712382550610)]
[外链图片转存中…(img-BZyOQFoE-1712382550610)]
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算