当前位置:K88软件开发文章中心网站服务器框架JFinal → 文章内容

5.9 表关联操作

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-25 14:21:58

由 厦门小懒懒 创建, 最后一次修改 2016-10-06 JFinal ActiveRecord 天然支持表关联操作,并不需要学习新的东西,此为无招胜有招。表 关联操作主要有两种方式:一是直接使用 sql 得到关联数据;二是在 Model 中添加获取关联数据的方法。假定现有两张数据库表:user、blog,并且 user 到 blog 是一对多关系,blog 表中使用 user_id关联到 user 表。如下代码演示使用第一种方式得到 user_name:public void relation() {String sql = "select b.*, u.user_name from blog b inner join user u on b.user_id=u.id where b.id=?";Blog blog = Blog.dao.findFirst(sql, 123); String name = blog.getStr("user_name");}以下代码演示第二种方式在 Blog 中获取相关联的 User 以及在 User 中获取相关联的Blog:public class Blog extends Model<Blog>{public static final Blog dao = new Blog(); public User getUser() {return User.dao.findById(get("user_id"));}}public class User extends Model<User>{public static final User dao = new User(); public List<Blog> getBlogs() {return Blog.dao.find("select * from blog where user_id=?", get("id"));}}

5.9 表关联操作