hibernate对多表的查询

来源:互联网 发布:非洲有网络吗 编辑:程序博客网 时间:2024/06/05 09:06

今天我们做一个多表查询。

1首先准备两张表,一张是学生信息表,一张是课程表。建表语句:

CREATE TABLE  `test`.`classinfo` (

 `classname` varchar(20) NOT NULL DEFAULT '',

 `classid` int(11) NOT NULL AUTO_INCREMENT,

 PRIMARY KEY (`classid`)

) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULTCHARSET=gbk;

 

CREATE TABLE  `test`.`student` (

 `id` int(11) NOT NULL AUTO_INCREMENT,

 `classid` int(11) DEFAULT NULL,

 `name` varchar(45) NOT NULL DEFAULT '',

 PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULTCHARSET=gbk;

这是量表的表表结构。我们知道这两张表具有关联关系。他们具有相同的classid。

那么如何利用hibernate实现对2表的查询呢?

 

 

实现代码如下:

第一建两张表的映射类分别是:

packagecom.fish.domain;

 

public class Classinfo {

    public Stringclassname;

    public int classid;

    public String getClassname() {

        returnclassname;

    }

    public void setClassname(String classname) {

        this.classname = classname;

    }

    public int getClassid() {

        returnclassid;

    }

    public void setClassid(int classid) {

        this.classid = classid;

    }

   

}

 

第二个类:

packagecom.fish.domain;

 

public class Student {

 public int id;

 public int classid;

 public Stringname ;

 public  Classinfoclassinfo;//这里做一个和上面表的的关联。

 

 

publicClassinfo getClassinfo() {

    return classinfo;

}

public void setClassinfo(Classinfo classinfo) {

    this.classinfo = classinfo;

}

public int getId() {

    return id;

}

public void setId(int id) {

    this.id = id;

}

public int getClassid() {

    return classid;

}

public void setClassid(int classid) {

    this.classid = classid;

}

publicString getName() {

    return name;

}

public void setName(String name) {

    this.name = name;

}

 

}

 

下面写两个关与表和类关联的类的xml

第一个xml。

<?xmlversion="1.0"encoding="UTF-8"?>

<!DOCTYPEhibernate-mapping PUBLIC

    "-//Hibernate/HibernateMapping DTD 3.0//EN"

    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

 

<hibernate-mapping>

    <classname="com.fish.domain.Classinfo"table="classinfo">

        <idname="classid">

            <columnname="classid"></column>

            <typename="java.lang.Integer"></type>

 

        </id>

        <propertyname="classname"column="classname"type="java.lang.String"></property>

    </class>

</hibernate-mapping>

 

 

 

第二个xml

<?xmlversion="1.0"encoding="UTF-8"?>

<!DOCTYPEhibernate-mapping PUBLIC

    "-//Hibernate/HibernateMapping DTD 3.0//EN"

    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

 

<hibernate-mapping>

    <classname="com.fish.domain.Student"table="student">

        <idname="id">

            <columnname="id"></column>

            <typename="java.lang.Integer"></type>

        </id>

        <propertyname="classid"column="classid"type="java.lang.Integer"></property>

        <propertyname="name"column="name"type="java.lang.String"></property>

        <many-to-onename="classinfo"column="classid"update="false"

            insert="false"></many-to-one>//首先要明白多个学生可以选一个课程。所以是多对一的关系,classid是两个表共同属性。在做关联的时候,对表示不允许插入和修改的所以为false

    </class>

</hibernate-mapping>

 

最后做一个和数据关联的xml

<!DOCTYPEhibernate-configuration PUBLIC

    "-//Hibernate/HibernateConfiguration DTD 3.0//EN"

    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

 

<hibernate-configuration>

    <session-factory>

        <propertyname="connection.driver_class">

            com.mysql.jdbc.Driver

        </property>

        <propertyname="connection.url">jdbc:mysql://127.0.0.1:3306/test</property>

        <propertyname="connection.username">root</property>

        <propertyname="connection.password">330127</property>

 

        <propertyname="dialect">org.hibernate.dialect.HSQLDialect</property>

        <propertyname="show_sql">false</property>

 

        <mapping resource="com/fish/domain/student.hbm.xml"/>//注册student已经关联上了

        <mapping resource="com/fish/domain/classinfo.hbm.xml"/>//同理

    </session-factory>

</hibernate-configuration>

 

 

下面做一个测试类

packagecom.fish.domain;

 

importjava.util.ArrayList;

 

importorg.hibernate.Query;

importorg.hibernate.Session;

importorg.hibernate.SessionFactory;

importorg.hibernate.cfg.Configuration;

 

public class Test {

public static void main(String[] args) {

    Configuration configuration = new Configuration();

    configuration.configure("hibernate.cfg.xml");

    SessionFactory factory =configuration.buildSessionFactory();

      

Sessionsession=    factory.openSession();

Queryquery= session.createQuery("from Student");//利用插学生表就可以拖带课程表

 ArrayList<Student> list= (ArrayList<Student>)query.list();

 for(int i=0;i<list.size();i++){

   

     System.out.println( list.get(i).getName()+"****"+list.get(i).getClassinfo().getClassname());//这句话的list.get(i).getClassinfo().getClassname()如果能调用出来显示就说明,关联成功!

 }

}

}

总结:利用这个方法我们可以查询出多表的信息但是有缺点的,这样我查询一个表,就等于查询了多个表的信息,这样就会导致性能下降!!!