当前位置: 首页 > 面试题库 >

ActiveAndroid多对多关系

杨和蔼
2023-03-14
问题内容

我目前正在使用ActiveAndroid,并且在过去的几个小时里一直在尝试建立多对多关系,但是我还是无法正常工作。我希望你能帮助我:

我有“学生”和“课程”的模型,一个学生可以有很多课程,而一个课程有很多学生。基本上,这就是我在“ StudentCourse”模型中所拥有的:

 @Column(name = COURSE)
 public Course course;

 @Column(name = STUDENT)
 public Student student;

 public StudentCourse(Student student, Course course) {
 super();
 this.student = student;
 this.course = course;
 }
//
 public StudentCourse(){ }

 public List<Course> courses(){
 return getMany(Course.class, "StudentCourse");
 }
 public List<Student> students(){
 return getMany(Student.class, "StudentCourse");
 }

现在,我要做的是使用以下代码获取“课程X中的所有学生”:

((Student) new Select().from(StudentCourse.class).where("course = ?",selectedCourse.getId()).executeSingle()).students();

但是我收到以下错误:

java.lang.ClassCastException:com.papinotas.models.StudentCourse无法转换为com.papinotas.models.Student

如果将(Student)的演员表更改为(StudentCourse),则会出现以下错误:

android.database.sqlite.SQLiteException:无此类列:students.StudentCourse(代码1):,同时进行编译:SELECT * FROM students在哪里凡学生.StudentCourse = 1

我的主要目标是希望仅通过1个查询即可实现这一目标。任何帮助将不胜感激。提前致谢!

PS:我已经查看了几乎所有可以找到的内容:活跃的Android多对多关系和https://github.com/pardom/ActiveAndroid/issues/46


问题答案:

我不会用getMany这个。我会这样做:

return new Select()
    .from(Student.class)
    .innerJoin(StudentCourse.class).on("students.id = studentcourses.id")
    .where("studentcourses.course = ?", courseId)
    .execute();


 类似资料:
  • 问题内容: 伙计们,我正在努力为我的公司制作一个简单的票证生成系统,以吸引人。目前,我的MSSQL数据库中有一个名为的表,另一个名为的表。 我的应用程序是C#Windows窗体,因此在新的票证生成窗体上,我有许多文本框和一个用于分配工程师的comboBox,由填充。生成票证后,以这种形式输入的所有信息都将与from一起存储。 效果很好,但是后来我的客户要求我添加选项,以便可以在一张票上分配3名工程

  • 在本章中,让我们了解和学习多对多的关系。要表示多对多关系,必须创建第三个表(通常称为联接表),将多对多关系分解为两个一对多关系。 为此,我们还需要添加一个联接表。 下面先添加一个表。表的定义如下所示 - 现在创建一个多对多的关系。假设有多个作者在多个项目上工作,反之亦然。 如您所知,我们在中有一个字段,所以为它创建了一个表。但现在不再需要这个字段了。 选择字段,然后按下删除 按钮,将看到以下消息。

  • 我还想知道如何定义每个模型上的关系--你是否需要或者是否可以只在用户上定义关系?

  • 比如我们要关联用户和角色之间的关系,就要用到多对多。多对多需要一张中间表来做关联。 定义 多对多关联会用到的注解: @ManyToMany、@JoinFromMiddle、@JoinToMiddle、@AutoSelect、@AutoInsert、@AutoUpdate、@AutoSave、@AutoDelete 如 imi-demo 中代码所示,类定义了一个$userRole属性和$role属性

  • 多对多关联 关联定义 例如,我们的用户和角色就是一种多对多的关系,我们在User模型定义如下: <?php namespace app\index\model; use think\Model; class User extends Model { public function roles() { return $this->belongsToMany('R