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

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

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

您需要创建以下页面来映射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<String, String> answers; public Question() {
} public Question(String name, String username, Map<String, String> 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<String, String> getAnswers() {
return answers;
} public void setAnswers(Map<String, String> answers) {
this.answers = answers;
} }
Java

文件: question.hbm.xml -

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="com.yiibai.Question" table="question_736">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<property name="username"></property> <map name="answers" table="answer736" cascade="all">
<key column="questionid"></key>
<index column="answer" type="string"></index>
<element column="username" type="string"></element>
</map>
</class> </hibernate-mapping>
XML

文件:hibernate.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration> <session-factory>
<property name="hbm2ddl.auto">update</property> <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<property name="show_sql">true</property> <mapping resource="question.hbm.xml" />
</session-factory> </hibernate-configuration>
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<String, String> map1 = new HashMap<String, String>();
map1.put("java is a programming language", "John Lee ");
map1.put("java is a platform", "Ashok Su"); HashMap<String, String> map2 = new HashMap<String, String>();
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<Question> list = query.list(); Iterator<Question> 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<String, String> map = question.getAnswers();
Set<Map.Entry<String, String>> set = map.entrySet(); Iterator<Map.Entry<String, String>> iteratoranswer = set.iterator();
while (iteratoranswer.hasNext()) {
Map.Entry<String, String> entry = (Map.Entry<String, String>) iteratoranswer
.next();
System.out.println("answer name:" + entry.getKey());
System.out.println("answer posted by:" + entry.getValue());
}
}
session.close();
}
}
Java

运行测试结果

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

  1. 执行 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
  2. 执行 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

集合Map映射(使用xml文件)的更多相关文章

  1. SQL 映射的 XML 文件

    MyBatis 真正的力量是在映射语句中.这里是奇迹发生的地方. 对于所有的力量, SQL映射的 XML 文件是相当的简单.当然如果你将它们和对等功能的 JDBC 代码来比较,你会发现映射文件节省了大 ...

  2. 五、SQL映射的XML文件

    MyBatis真正的力量是在映射语句中.这里是奇迹发生的地方.对于所有的力量,SQL映射的XML文件是相当的简单.当然如果你将它们和对等功能的JDBC代码来比较,你会发现映射文件节省了大约95%的代码 ...

  3. Python连载43-current中的map函数、xml文件

    一.current中的map函数 1.map(fn,*iterable,timeout=None) (1)跟map函数相类似(2)函数需要异步执行(3)timeout代表超时时间 (4)map和sub ...

  4. IDEA Mybatis 找不到映射器xml文件

    用IDEA新建了一个测试MyBatis工程,工程目录如下 其中config是MyBatis的配置文件,内容如下 <?xml version="1.0" encoding=&q ...

  5. mybatis 找不到映射器xml文件 (idea)

    原因是: idea不会编译src的java目录的xml文件 所以解决思路就是:将IDEA maven项目中src源代码下的xml等资源文件编译进classes文件夹 具体操作方法就是:配置maven的 ...

  6. Spring中注入List,Set,Map,Properties的xml文件配置方法

    下面的例子展示了如何注入 List – <list/> Set – <set/> Map – <map/> Properties – <props/> ...

  7. MyBatis学习(四)XML配置文件之SQL映射的XML文件

    SQL映射文件常用的元素: 1.select 查询语句是MyBatis最常用的语句之一. 执行简单查询的select元素是非常简单的: <select id="selectUser&q ...

  8. Could not find resource——mybatis 找不到映射器xml文件

    今天用IDEA写Mybatis的时候,测试报了如图所示的错,恶心死我了,后来解决了,总结一下,防止下回跳坑,当然,也是做一个分享,如果有朋友遇到这个错,希望有所帮助 Error parsing SQL ...

  9. 集合Map多对多映射(使用xml文件)

    我们可以使用set,bag,map等来映射多对多关系.在这里,我们将使用map来进行多对多映射. 在这种情况下,将创建三个表. 多对多映射示例 我们需要创建以下文件来映射map元素.首先创建一个项目: ...

随机推荐

  1. Microsoft-PetSop4.0(宠物商店)-数据库设计-Sql

    ylbtech-DatabaseDesgin:Microsoft-PetSop4.0(宠物商店)-数据库设计-Sql DatabaseName:PetShop(宠物商店) Model:宠物商店网站 T ...

  2. [转载]使用32位64位交叉编码混淆来打败静态和动态分析工具 - wildsator

    0×00 摘要 混淆是一种能增加二进制分析和逆向工程难度与成本的常用技术.主流的混淆技术都是着眼于使用与目标CPU相同的机器代码,在相同的处理器模式下,隐藏代码并进行控制.本文中引入了一种新的混淆方法 ...

  3. N的阶层(王道)

    题目描述: 输入一个正整数N,输出N的阶乘. 输入: 正整数N(0<=N<=1000) 输出: 输入可能包括多组数据,对于每一组输入数据,输出N的阶乘 样例输入: 4 5 15 样例输出: ...

  4. linux 输出重定向 何时会写文件

    linux 输出重定向 何时会写文件 测试到了8K才会进行flush:

  5. [转] Google 开源 iOS 应用测试工具:EarlGrey

    Google 开源 iOS 应用测试工具:EarlGrey oschina 发布于: 2016年02月18日 (3评) 分享到:    收藏 +53 3月19日,深圳源创会火热报名中,go>&g ...

  6. 正则表达式表示 ja.resx 所在行

    [^\n]*ja.resx[^\n]*\n?正则表达式表示 ja.resx 所在行 用ultraEdit 删除关键字所在行的下一行或是上一行,所在行保留 删除 关键字所在行 的前3行: (^.*?(\ ...

  7. css水平竖直居中方式

    CSS水平和垂直居中的几种实现方法: 1.单行垂直居中 文字在层中垂直居中vertical-align 属性是做不到的.我们这里有个比较巧妙的方法就是:设置height的高度与line-height的 ...

  8. css - 公众号样式

    /* * @Author: WJ_LONG * @Date: 2018-09-06 15:32:06 * @Last Modified by: WJ_LONG * @Last Modified tim ...

  9. Ant 风格路径表达式(转)

    ANT通配符有三种: 通配符 说明 ? 匹配任何单字符 * 匹配0或者任意数量的字符 ** 匹配0或者更多的目录 例子: URL路径 说明 /app/*.x 匹配(Matches)所有在app路径下的 ...

  10. Android 自己定义控件开发入门(二)

    上一次我们讲了一堆实现自己定义控件的理论基础.列举了View类一些能够重写的方法,我们对这些方法的重写是我们继承View类来派生自己定义控件的关键 我通过一个最简单的样例给大家展示了这一个过程,不管是 ...