create table EMPLOYEE
(
ID NUMBER(10) not null,
parentID number(10),
NAME VARCHAR2(20),
AGE NUMBER(3),
PASSWARD VARCHAR2(12),
CSRQ DATE,
PICTURE varchar(12),
primary key(id),
foreign key(parentID) references department(id)
)
drop table department
create table department
(
id number(10) not null,
dep_id varchar2(20),
dep_mc varchar2(20),
primary key(id)
)
其中,employee表中的parentID是department表的外键,department和employee表是一对多的关系,反过来是多对一的关系。怎么叫都可以。
Department.hbm.xml代码如下:
<hibernate-mapping>
<class name="com.dudeng.employee.hibernate.vo.Department"
table="DEPARTMENT" schema="DUDENG">
<id name="id" type="java.lang.Long">
<column name="ID" precision="10" scale="0" />
<generator class="sequence">
<param name="sequence">seq_department</param>
</generator>
</id>
<property name="dep_id" type="java.lang.String">
<column name="DEP_ID" length="20" not-null="false" />
</property>
<property name="dep_mc" type="java.lang.String">
<column name="DEP_MC" length="20" not-null="false" />
</property>
<set name="employees" inverse="true"> 注:inverse="true"表示由多一方来维护
<key>
<column name="parentID" precision="5" scale="0"
not-null="true" />
</key>
<one-to-many
class="com.dudeng.employee.hibernate.vo.Employee" />
</set> </class>
</hibernate-mapping>
Employee.hbm.xml的代码如下:
<hibernate-mapping>
<class name="com.dudeng.employee.hibernate.vo.Employee"
table="EMPLOYEE" schema="DUDENG">
<id name="id" type="java.lang.Long">
<column name="ID" precision="10" scale="0" />
<generator class="sequence">
<param name="sequence">seq_employee</param>
</generator>
</id>
<many-to-one name="department" class="com.dudeng.employee.hibernate.vo.Department">
<column name="parentID" precision="5" scale="0" not-null="true" /> </many-to-one>
<property name="name" type="java.lang.String">
<column name="NAME" length="20" not-null="false" />
</property>
<property name="age" type="java.lang.Long">
<column name="AGE" precision="3" scale="0" not-null="false" />
</property>
<property name="passward" type="java.lang.String">
<column name="PASSWARD" length="12" not-null="false" />
</property>
<property name="csrq" type="java.util.Date">
<column name="CSRQ" length="7" not-null="false" />
</property>
<property name="picture" type="java.lang.String">
<column name="PICTURE" length="20" not-null="false"/>
</property>
</class>
</hibernate-mapping>
查询结果集合:
List list = null;
String QueryStr = "from Employee emp,Department dep where emp.department = dep.id";
EmployeeBiz empbiz = EmployeeBiz.getInstance();
list = empbiz.find(QueryStr);
for (int i = 0; i < list.size(); i++)
{
Object[] obj = (Object[]) list.get(i);
for (int j = 0; j < obj.length; j++)
{
if (obj[j] instanceof Employee)
{
Employee emp = (Employee) obj[j];
System.out.print(emp.getName());
}
elseif (obj[j] instanceof Department)
{
Department dep = (Department) obj[j];
System.out.print(dep.getDep_mc());
}
}
System.out.println();
}
以上特别注意的地方:emp.department不能写成emp.parentID,我上网查了半天才找出原因的。开始写成emp.parentID了,后来改成emp.department程序运行正常了
分享到:
相关推荐
Oracle基础练习题及答案(多表查询1)Oracle基础练习题及答案(多表查询1).
Ibatis多表查询,一个小小的多表查询实例教你如何用ibatis进行多表查询
本文实例讲述了MySQL 多表关联一对多查询实现取最新一条数据的方法。分享给大家供大家参考,具体如下: MySQL 多表关联一对多查询取最新的一条数据 遇到的问题 多表关联一对多查询取最新的一条数据,数据出现重复 ...
day19--mysql多表查询1
本文实例讲述了thinkPHP框架实现多表查询的方法。分享给大家供大家参考,具体如下: 我们可以将两个表连起来一起查询数据,我现在有两张表,一个是feedback表和member表,如图: 总目录: 上代码: $where = ...
我在网上找了很多资料都没有办法,现在我告诉你们如何做一个多表查询,可能会比较麻烦,那就是先做一个视图,然后对视图查询..这样的办法不算高明,但是我暂时还没有资料找到如何多表查询
1.利用FROM子句进行多表查询:select kjbdsjk.编号,kjbdsjk.姓名,kjbdsjk.职业,duobiao.收入 from kjbdsjk,duobiao where kjbdsjk.编号 = duobiao.编号 and duobiao.收入 >3000 2.合并多个结果集:select 编号,姓名,...
数据库实验一多表查询的实验报告格式内容题目等,只要是基于数据库的知识展开的实验。
第06章_多表查询讲师:尚硅谷-宋红康(江湖人称:康师傅)多表查询,也称为关联查询,指两个或更多个表一起完成查询操作。前提条件:这些一起查询的表之间是有关系的
sql多表关联查询
ODBC编程中,不可能只有一个数据表,多表查询SQL语句同样胜任!
数据库是以一定方式储存在一起、能与多个用户共享、具有尽可能小的冗余度、与应用程序彼此独立的数据集合,可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据进行新增、查询、更新、删除等操作
sql视图与多表查询
实验目的: 1. 掌握GROUP BY语句和聚合函数的使用。 2. 掌握多表连接查询、子查询的基本概念。 3. 掌握多表连接的各种... 分组查询、多表连接查询、子查询,具体内容参见实验指导手册。 二、实验器材 计算机、MySQL8.0
在excel中,多工作簿多工作表数据查询,有三种方法,可自行选择
MyBatis Plus 的多表联接、分页查询实现方法 http://localhost/common/getAllQuestionByPage/1/10 多表关联、分页查询接口 http://localhost/common/getAllQuestionWithStudentByPage/1/10 多表关联、分页带参数查询...
3、测试数据说明超女基本信息历史表(T_GIRL_HIS)中有4条记录,超女基本信息表(T_GIRL)中有3条记录,两个表中有相交的记录('0103'、'010
sql的多表查询。详细介绍与分解。 多表查询 等连接 通过两个表具有相同意义的列,建立连接条件. 查询结果只显示两个列中的值是等值条件的行数据 表中同名列被选择时必须添加表名前缀进行修饰 否则无法确定这一列...
ACCESS数据库多表关联查询例程。@易语言数据库教程。