Hibernate.cfg.xml主配置文件

主配置文件中主要配置:数据库连接信息、其他参数、映射信息!

常用配置查看源码:

hibernate-distribution-3.6.0.Final\project\etc\hibernate.properties(键值对的形式展现)

如:

.....
## Microsoft Driver (not recommended!)
#hibernate.connection.driver_class com.microsoft.jdbc.sqlserver.SQLServerDriver
#hibernate.connection.url jdbc:microsoft:sqlserver://1E1;DatabaseName=test;SelectMethod=cursor

## The New Microsoft Driver
#hibernate.connection.driver_class com.microsoft.sqlserver.jdbc.SQLServerDriver
#hibernate.connection.url jdbc:sqlserver://localhost
........

自动建表

#hibernate.hbm2ddl.auto create-drop 每次在创建sessionFactory时候执行创建表; 当调用sesisonFactory的close方法的时候,删除表!

#hibernate.hbm2ddl.auto create   每次都重新建表; 如果表已经存在就先删除再创建

#hibernate.hbm2ddl.auto update  如果表不存在就创建; 表存在就不创建;

#hibernate.hbm2ddl.auto validate  (生成环境时候) 执行验证: 当映射文件的内容与数据库表结构不一样的时候就报错!

<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory>
		<!-- 数据库连接配置 -->
		<property name="hibernate.connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
		<property name="hibernate.connection.url">jdbc:sqlserver://localhost:1433;DataBaseName=Test</property>
		<property name="hibernate.connection.username">sa</property>
		<property name="hibernate.connection.password">123456</property>
			<!-- 生成指定的sql语言 -->
		<property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property>
			<!-- 为了更好的展示效果,在控制台打印sql语句 -->
		<property name="hibernate.show_sql">true</property>
			<!-- 格式化sql语句 -->
		<property name="hibernate.format_sql">true</property>
			<!-- 自动创建表 -->
		<property name="hibernate.hbm2ddl.auto">update</property>

		<!-- 加载所有映射
		<mapping resource="com/gqx/api/User.hbm.xml"/>
		-->
		 <mapping resource="com/gqx/demo1/User.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

映射配置文件

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!--
	映射文件:映射一个实体类对象;描述一个对象最终实现可以直接保存对象数据到数据库中
	 -->
<!--
	package:要映射的对象所在的包(可选,若不指定,则文件的类都要指定全路径
 -->
<hibernate-mapping  package="com.gqx.api">

	<!--
		class:映射的某一个对象(一般情况,一个对象写一个映射文件,寄一个class节点
		  name:指定要映射的对象的类型
		  table:对象对应的表(如果没有指定,默认和对象名一样)
	 -->
	<class name="User" table="users2">
		<!-- 主键字段 -->
		<id name="id" column="uid">
			<!-- 主键的生成策略
				native :自增长(功能强大,根据数据库自动选择identity或sequence
				increment:自增长(会有并发访问的问题,一般在服务器集群环境使用会存在问题)

				assigned:指定主键生成策略为手动指定主键的值
				uuid:指定UUID随机生成的唯一的值
			 -->
			<generator class="native"/>
		</id>
		<!--
			 非主键
			 如果列明为数据库的关键字,需要用反引号或改列名
			 name:指定对象的属性名称
			 column:指定对象属性对应的表的字段名称
			 length:指定字符串的长度,默认255
			 type:指定映射表的字段类型,如果不指定会匹配属性的类型

			  -->
		<property name="name" column="name" type="java.lang.String" length="40"></property>
		<property name="password" column="password"></property>
	</class>

</hibernate-mapping>

复合主键映射

1、创建一个复合主键类

package com.gqx.demo2;

import java.io.Serializable;

//复合主键类
public class CompositeKeys implements Serializable {

	private static final long serialVersionUID = 1L;
	private String name;
	private String address;
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAddress() {
		return address;
	}
	public void setAddress(String address) {
		this.address = address;
	}

}

2、创建完整类对象

package com.gqx.demo2;

public class Employee {
	//名字和地址不能重复
	private CompositeKeys keys;
	private int age;

	public CompositeKeys getKeys() {
		return keys;
	}
	public void setKeys(CompositeKeys keys) {
		this.keys = keys;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}

}

写映射配置文件

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping  package="com.gqx.demo2">

	<class name="Employee" >
		<!-- 符合主键映射 -->
		<composite-id name="keys">
			<key-property name="name" type="string"></key-property>
			<key-property name="address" type="string"></key-property>
		</composite-id>
		<property name="age" type="int"></property>
	</class>

</hibernate-mapping>

最后则是测试类

package com.gqx.demo2;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;
public class test {
	private static SessionFactory sf;
	static{
		sf=new Configuration()
		.configure().addClass(Employee.class)
		.buildSessionFactory();
	}
	@Test
	public void test() {
		Session session=sf.openSession();
		Transaction transaction=session.beginTransaction();
		CompositeKeys keys=new CompositeKeys();
		keys.setName("test");
		keys.setAddress("湖北黄石");

		Employee employee=new Employee();
		employee.setAge(21);
		employee.setKeys(keys);
		session.save(employee);

		transaction.commit();
		session.close();
		sf.close();
	}

}

你就会看到数据库会新增一条记录。


js:伸缩文字,如下图效果:

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>收缩文字</title>
    <style type="text/css" media="screen">
    #div1 {
        width: 200px;
        min-height: 20px;
        border: 1px #000 solid;
    }
    </style>
</head>

<body>
    <input type="button" value="展开">
    <input type="button" value="收缩">
    <div id="div1"></div>
    <script type="text/javascript">
    var aInput = document.getElementsByTagName('input');
    var oDiv = document.getElementById('div1');
    var str = 'Enjoy your youth. You’ll never be younger than you are at this very moment. 尽情享受你的青春,你永远不会比此刻更年轻了。';
    var timer = null;
    var arr = str.split('');
    aInput[0].onclick = function() {
    	clearInterval(timer);
        timer = setInterval(function() {
            //shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。
            var val = arr.shift();
            oDiv.innerHTML += val;
            if (arr.length == 0) {
                clearInterval(timer);
            }
        }, 50)
    }

    aInput[1].onclick = function() {
        var arr2 = oDiv.innerHTML.split('');
        clearInterval(timer);
        timer = setInterval(function() {
            //unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。
            arr.unshift(arr2.pop());
            //join() 方法用于把数组中的所有元素放入一个字符串。
            oDiv.innerHTML=arr2.join('');
            if (arr2.length==0) {
            	clearInterval(timer);
            }
        },50);
    }
    </script>
</body>

</html>

Hibernate主配置文件、映射配置文件以及复合主键查询的更多相关文章

  1. Hibernate第三篇【主配置文件、映射文件、复合主键映射】

    前言 目前已经学了如何搭建Hibernate的开发环境,以及Hibernate对应的API了-在快速入门还没讲解的就是配置文件是怎么配置的.因此,本博文主要讲解主配置文件以及映射配置文件.. 主配置文 ...

  2. Hibernate征途(七)之复合主键映射和集合映射

    把这两种映射放到一起说,是因为这两种映射不像前面的复用型映射.数量和方向型映射那么分类鲜明,所以放到了这个“其他”里面. 复合主键映射 在关系模型中,复合主键和其他的主键方式没有很大区别,但是反映到对 ...

  3. 【hibernate/JPA】注解方式实现 复合主键【spring boot】

    1>hibernate/JPA实现复合主键的思路:是将所有的主键属性封装在一个主键类中,提供给需要复合主键的实体类使用. 2>主键类的几点要求: . 使用复合主键的实体类必须实现Seria ...

  4. Hibernate学习笔记--映射配置文件详解

    参考资料: http://blog.163.com/hzd_love/blog/static/13199988120108265317988/ http://www.cnblogs.com/often ...

  5. Hibernate复合主键映射

    目录: 1. 实现方式一:将复合主键对应的属性与实体其他普通属性放在一起 2. 实现方式二:将主键属性提取到一个主键类中,实体类只需包含主键类的一个引用 在日常开发中会遇到这样一种情况,数据库中的某张 ...

  6. hibernate复合主键

    需要用到实体类Role的主键和Menu的主键结合起来作为实体类RoleMenu的主键,那么通过Hibernate具体实现如下: RoleMenu实体类:(注意该实体类需要实现Serializable接 ...

  7. Hibernate框架 主配置文件 Hibernate.cfg.xml 映射配置 说明

    1 主配置文件 Hibernate.cfg.xml 主配置文件中主要配置:数据库连接信息.其他参数.映射信息! 常用配置查看源码: hibernate-distribution-3.6.0.Final ...

  8. 【Hibernate步步为营】--复合主键映射具体解释

    上篇文章讨论了继承映射,它是对象模型中最主要的特性,对于继承映射它的主要区分是字段类型的不同,所以在生成表结构时须要有新列来标识数据的类型,能够使用<subclass>标签并在标签中加入d ...

  9. Hibernate 表映射 主键生成策略与复合主键

    主要分析三点: 一.数据表和Java类的映射 : 二.单一主键映射和主键的生成策略 : 三.复合主键的表映射 : 一.数据表和Java类的映射  Hibernate封装了数据库DDL语句,只需要将数据 ...

随机推荐

  1. phpwind部署问题

    1. 提示"PDO_Mysql 未安装" wamp安装后,首选确保在wamp/php/ext/目录下存在"php_pdo.dll"和"php_pdo_ ...

  2. 关于MVC视图传参

    转自:http://q.cnblogs.com/q/48477/

  3. web-day3

    第3章WEB03- JS篇 今日任务 使用JS完成图片轮播效果 使用JS完成页面定时弹出广告 使用JS完成表单的校验 使用JS完成表格的隔行换色 使用JS完成复选框的全选效果 使用JS完成省市联动效果 ...

  4. iOS中的序列帧动画

    UIImageView对象的有一个animationImages属性,将图片数组赋值给该属性即可.如图: 控制动画的播放方法是:[ ___  startAnimating]; 控制动画的停止方法是:[ ...

  5. TF-IDF模型的概率解释

    信息检索概述 信息检索是当前应用十分广泛的一种技术,论文检索.搜索引擎都属于信息检索的范畴.通常,人们把信息检索问题抽象为:在文档集合D上,对于由关键词w[1] … w[k]组成的查询串q,返回一个按 ...

  6. 锁——Java同步的基本思想

    翻译人员: 铁锚 翻译时间: 2013年11月13日 原文链接:  Monitors – The Basic Idea of Java synchronization 如果你上过操作系统课程,你就知道 ...

  7. AngularJS 控制器 Live Dom

    控制器的作用是在$scope对象上创建属性和方法,控制器的作用域是$scope,所以作用域是针对控制器来讲的.另外,控制器实例不是单例,每次都会重新实例化,不像服务是单例的. 其是注册在模块上的,如 ...

  8. Kali Linux渗透测试实战 1.3 渗透测试的一般化流程

    1.3 渗透测试的一般化流程 凡事预则立,不预则废,做任何事情都要有一个预先的计划.渗透测试作为测试学科的一个分支,早已形成了完整的方法论.在正式开始本书的实践教学章节之前,我也想谈一谈使用Kali ...

  9. ABP框架入门踩坑-配置数据库表前缀

    配置数据库表前缀 ABP踩坑记录-目录 本篇其实和ABP关系并不大,主要是EF Core的一些应用-.-. 起因 支持数据库表前缀应该是很多应用中比较常见的功能,而在ABP中并没直接提供这一功能,所以 ...

  10. 迁移桌面程序到MS Store(6)——.NET Portability Analyzer

    上一篇我们简单介绍了.NET Standard,本篇我们来实践.NET Framework 4.5 Class Library到.NET Standard 2.0的转换.        首先让我们来做 ...