Hibernate允许我们将Map元素与RDBMS进行映射。 我们知道,List和Map是基于索引的集合。 在map的情况下,索引列作为键,元素列用作值。

使用xml文件在集合映射中映射Map的示例

现在,我们创建一个Java工程:ternarystring,项目的完整目录结构如下图所示 -

067a2d69917bfc08cd73d6a5e1cac37c.png

您需要创建以下页面来映射Map元素。

Question.java

question.hbm.xml

hibernate.cfg.xml

MainTest.java

FetchTest.java

文件:Question.java -

package com.yiibai;

import java.util.Map;

public class Question {

private int id;

private String name, username;

private Map answers;

public Question() {

}

public Question(String name, String username, Map answers) {

super();

this.name = name;

this.username = username;

this.answers = answers;

}

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;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public Map getAnswers() {

return answers;

}

public void setAnswers(Map answers) {

this.answers = answers;

}

}

Java

文件: question.hbm.xml -

/p>

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

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

XML

文件:hibernate.cfg.xml

/p>

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

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

update

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/test

root

123456

org.hibernate.dialect.MySQL5InnoDBDialect

true

XML

文件:MainTest.java

package com.yiibai;

import java.util.HashMap;

import org.hibernate.*;

import org.hibernate.boot.MetadataSources;

import org.hibernate.boot.registry.StandardServiceRegistry;

import org.hibernate.boot.registry.StandardServiceRegistryBuilder;

import org.hibernate.cfg.*;

public class MainTest {

public static void main(String[] args) {

// 在5.1.0版本汇总,hibernate则采用如下新方式获取:

// 1. 配置类型安全的准服务注册类,这是当前应用的单例对象,不作修改,所以声明为final

// 在configure("cfg/hibernate.cfg.xml")方法中,如果不指定资源路径,默认在类路径下寻找名为hibernate.cfg.xml的文件

final StandardServiceRegistry registry = new StandardServiceRegistryBuilder()

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

// 2. 根据服务注册类创建一个元数据资源集,同时构建元数据并生成应用一般唯一的的session工厂

SessionFactory sessionFactory = new MetadataSources(registry)

.buildMetadata().buildSessionFactory();

/**** 上面是配置准备,下面开始我们的数据库操作 ******/

Session session = sessionFactory.openSession();// 从会话工厂获取一个session

// creating transaction object

Transaction t = session.beginTransaction();

HashMap map1 = new HashMap();

map1.put("java is a programming language", "John Lee ");

map1.put("java is a platform", "Ashok Su");

HashMap map2 = new HashMap();

map2.put("servlet technology is a server side programming",

"John Milton");

map2.put("Servlet is an Interface", "Ashok Lee");

map2.put("Servlet is a package", "Rahul Su");

Question question1 = new Question("What is java?", "Alok", map1);

Question question2 = new Question("What is servlet?", "Jai Dixit", map2);

session.persist(question1);

session.persist(question2);

t.commit();

session.close();

System.out.println("successfully stored");

}

}

Java

文件: FetchTest.java -

package com.yiibai;

import java.util.*;

import org.hibernate.*;

import org.hibernate.cfg.*;

public class FetchTest {

public static void main(String[] args) {

Session session = new Configuration().configure().buildSessionFactory()

.openSession();

Query query = session.createQuery("from Question ");

List list = query.list();

Iterator iterator = list.iterator();

while (iterator.hasNext()) {

Question question = iterator.next();

System.out.println("question id:" + question.getId());

System.out.println("question name:" + question.getName());

System.out.println("question posted by:" + question.getUsername());

System.out.println("answers.....");

Map map = question.getAnswers();

Set> set = map.entrySet();

Iterator> iteratoranswer = set.iterator();

while (iteratoranswer.hasNext()) {

Map.Entry entry = (Map.Entry) iteratoranswer

.next();

System.out.println("answer name:" + entry.getKey());

System.out.println("answer posted by:" + entry.getValue());

}

}

session.close();

}

}

Java

运行测试结果

首先,运行 MainTest.java 以插入数据,然后运行 FetchTest.java查询数据 -

执行 MainTest.java 结果如下所示 -

log4j:WARN No appenders could be found for logger (org.jboss.logging).

log4j:WARN Please initialize the log4j system properly.

log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

Mon Mar 27 02:31:54 CST 2017 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.

Hibernate: create table answer736 (questionid integer not null, answer varchar(255) not null, username varchar(255), primary key (questionid, answer)) engine=InnoDB

Hibernate: create table question_736 (id integer not null auto_increment, name varchar(255), username varchar(255), primary key (id)) engine=InnoDB

Hibernate: alter table answer736 add constraint FK8a0ar72dc6qqqh79ujtwm4w9o foreign key (questionid) references question_736 (id)

Hibernate: insert into question_736 (name, username) values (?, ?)

Hibernate: insert into question_736 (name, username) values (?, ?)

Hibernate: insert into answer736 (questionid, answer, username) values (?, ?, ?)

Hibernate: insert into answer736 (questionid, answer, username) values (?, ?, ?)

Hibernate: insert into answer736 (questionid, answer, username) values (?, ?, ?)

Hibernate: insert into answer736 (questionid, answer, username) values (?, ?, ?)

Hibernate: insert into answer736 (questionid, answer, username) values (?, ?, ?)

successfully stored

Shell

执行 FetchTest.java 结果如下所示 -

log4j:WARN No appenders could be found for logger (org.jboss.logging).

log4j:WARN Please initialize the log4j system properly.

log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

Mon Mar 27 02:34:17 CST 2017 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.

Hibernate: select question0_.id as id1_1_, question0_.name as name2_1_, question0_.username as username3_1_ from question_736 question0_

question id:1

question name:What is java?

question posted by:Alok

answers.....

Hibernate: select answers0_.questionid as question1_0_0_, answers0_.username as username3_0_0_, answers0_.answer as answer2_0_ from answer736 answers0_ where answers0_.questionid=?

answer name:java is a programming language

answer posted by:John Lee

answer name:java is a platform

answer posted by:Ashok Su

question id:2

question name:What is servlet?

question posted by:Jai Dixit

answers.....

Hibernate: select answers0_.questionid as question1_0_0_, answers0_.username as username3_0_0_, answers0_.answer as answer2_0_ from answer736 answers0_ where answers0_.questionid=?

answer name:Servlet is a package

answer posted by:Rahul Su

answer name:servlet technology is a server side programming

answer posted by:John Milton

answer name:Servlet is an Interface

answer posted by:Ashok Lee

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐