1、环境:

Maven :3.1.1

开发工具:Spring Tool Suite

数据库 : Mysql  5.6

2、项目文件结构

文件代码:

2.1 、pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>hibernate</groupId>
<artifactId>hibernate</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging> <name>hibernate</name>
<url>http://maven.apache.org</url> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> <dependencies>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.3.5.Final</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.30</version>
</dependency> <dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>

 2.2 、HibernateUtil.java

package com.rhythmk.hibernate01;

import javax.imageio.spi.ServiceRegistry;

import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistryBuilder; /*
* 参考 URL:
* http://docs.jboss.org/hibernate/orm/4.2/manual/en-US/html_single/
* */
public class HibernateUtil {
// By : rhythmk.cnblogs.com
private static final SessionFactory sessionFactory = buildSessionFactory(); private static SessionFactory buildSessionFactory() {
try { Configuration configuration=new Configuration().configure(); return configuration.buildSessionFactory(new ServiceRegistryBuilder().applySettings(configuration.getProperties()).build()); }
catch (Throwable ex) { System.err.println("Initial SessionFactory creation failed." + ex);
throw new ExceptionInInitializerError(ex);
} } public static SessionFactory getSessionFactory() {
return sessionFactory;
}
}

  

2.3、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="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="connection.url">jdbc:mysql://localhost:3306/shishuocms</property>
<property name="connection.username">root</property>
<property name="connection.password">wangkun</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="myeclipse.connection.profile">com.mysql.jdbc.Driver</property>
<!--是否在后台显示Hibernate用到的SQL语句,开发时设置为true,便于差错,程序运行时可以在Eclipse的控制台显示Hibernate的执行Sql语句。项目部署后可以设置为false,提高运行效率 -->
<property name="hibernate.show_sql">true </property>
<mapping resource="com/rhythmk/model/user.hbm.xml" />
</session-factory> </hibernate-configuration>

2.4 User.java

package com.rhythmk.model;

import java.util.Date;

public class User {
public Integer getUserId() {
return userId;
} public void setUserId(Integer userId) {
this.userId = userId;
} public Integer getOpenId() {
return openId;
} public void setOpenId(Integer openId) {
this.openId = openId;
} @Override
public String toString() { return "User [userId=" + userId + ", openId=" + openId + ", type="
+ type + ", name=" + name + ", createTime=" + createTime + "]";
} public String getType() {
return type;
} public void setType(String type) {
this.type = type;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Date getCreateTime() {
return createTime;
} public void setCreateTime(Date createTime) {
this.createTime = createTime;
} public Integer userId;
public Integer openId;
public String type;
public String name;
public Date createTime;
}

  2.5  user.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.rhythmk.model.User" table="user">
<id name="userId" type="int">
<column name="userId" />
<generator class="native" />
</id>
<property name="openId" type="int">
<column name="openId" not-null="true" />
</property>
<property name="type" type="string">
<column name="type" not-null="true" />
</property>
<property name="name" type="string">
<column name="name" length="45" not-null="true" />
</property>
<property name="createTime" type="timestamp">
<column name="createTime" not-null="true" />
</property> </class>
</hibernate-mapping>

3、测试代码(hibernatedemo1.java):

 插入:

@Test
public void InsertUser() { SessionFactory sessionfac = HibernateUtil.getSessionFactory(); Session session = null;
org.hibernate.Transaction tran = null;
try {
sessionfac.openSession();
User entity = new User();
tran = session.beginTransaction();
entity.setType("管理员");
entity.setName("rhythmk");
entity.setOpenId(1);
entity.setCreateTime(new Date());
session.save(entity);
tran.commit(); System.out.println("Insert into OK!");
} catch (Exception e) {
if (tran != null) {
tran.rollback();
}
e.printStackTrace();
} finally {
if (session != null)
session.close(); } }

  修改:

	@Test
public void UpdateUser() {
Session session = null;
org.hibernate.Transaction tran = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
tran = session.beginTransaction();
User entity = (User) session.load(User.class, 2);
entity.setName("Update");
session.save(entity);
tran.commit(); entity = (User) session.load(User.class, 2); System.out.println(entity.toString()); } catch (Exception e) {
if (tran != null) {
tran.rollback();
}
// TODO: handle exception
e.printStackTrace(); } finally {
if (session != null)
session.close(); }
}

  删除:

@Test
public void DelUser() { Session session = null;
org.hibernate.Transaction tran = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
tran = session.beginTransaction();
Object obj = session.load(User.class, 4);
User entity = null;
if (obj != null) {
entity = (User) obj;
} if (entity != null) {
session.delete(entity);
System.out.println("删除成功!");
tran.commit();
} } catch (Exception e) {
if (tran != null) {
tran.rollback();
}
// TODO: handle exception
e.printStackTrace(); } finally {
if (session != null)
session.close(); } }

  单对象查询

@Test
public void SelectUser() {
Session session = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
User entity = (User) session.load(User.class, 2);
System.out.println(entity.toString()); } catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
} finally {
if (session != null)
session.close(); } }

 List查询

  

@Test
public void SelectListUser() {
Session session = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
Query query= session.createQuery("from User ");
List<User> list=(List<User>)query.list();
for (User user : list) {
System.out.println(user);
} } catch (Exception e) {
e.printStackTrace();
} finally {
if (session != null)
session.close(); }
}

  分页查询:

	@Test
public void SelectPageListUser() {
// 获取分页数据
Session session = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
Query query= session.createQuery("from User ");
List<User> list=(List<User>)query
.setFirstResult(0) //从0项开始
.setMaxResults(3) //每页三条数据
.list();
for (User user : list) {
System.out.println(user);
} } catch (Exception e) {
e.printStackTrace();
} finally {
if (session != null)
session.close(); }
}

  代码包:http://pan.baidu.com/s/1hq1esh2

备注:

添加 JBOOS TOOL路径
http://download.jboss.org/jbosstools/updates/stable/helios/

Rhythmk 学习 Hibernate 01 - maven 创建Hibernate 项目之 增删改查入门的更多相关文章

  1. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  2. 使用MVC5+Entity Framework6的Code First模式创建数据库并实现增删改查功能

    此处采用VS2017+SqlServer数据库 一.创建项目并引用dll: 1.创建一个MVC项目 2.采用Nuget安装EF6.1.3 二.创建Model 在models文件夹中,建立相应的mode ...

  3. BitAdminCore框架应用篇:(二)创建一个简单的增删改查模块

    NET Core应用框架之BitAdminCore框架应用篇系列 框架演示:http://bit.bitdao.cn 框架源码:https://github.com/chenyinxin/cookie ...

  4. 数据库开发基础-SQl Server 控制数据库的服务+数据库的创建与管理(增删改查)

    控制数据库的服务: 方法一: 1.Windows+R 打开运行  打开cmd 2.输入net start MSSQLserver 启动数据库服务 输入net stop MSSQLserver 关闭数据 ...

  5. 数据库开发基础-★SQl Server 控制数据库的服务+数据库的创建与管理(增删改查)★

    控制数据库的服务: 方法一: 1.Windows+R 打开运行  打开cmd 2.输入net start MSSQLserver 启动数据库服务 输入net stop MSSQLserver 关闭数据 ...

  6. 【黑马Android】(04)数据库的创建和sql语句增删改查/LinearLayout展示列表数据/ListView的使用和BaseAdater/内容提供者创建

    数据库的创建和sql语句增删改查 1. 载入驱动. 2. 连接数据库. 3. 操作数据库. 创建表: create table person( _id integer primary key, nam ...

  7. Hibernate第一个程序(最基础的增删改查) --Hibernate

    本例实现Hibernate的第一个程序,Hibernate的优点我想大家都很清楚,在这里不做过多赘述.总之,使用Hibernate对数据库操作,也就是来操作实体对象的! 项目目录: 一.第一步要做的就 ...

  8. hibernate 一对多 多对一 关系表 增删改查大礼包ps二级查也有

    今天来到混元气功 这货大概的意思就是你中有我 我中有你 ps 这里就要说到维护关系 ps写这个用了我一下午.......也是刚刚好复习到这里 顺便就写写 注意:一般都在多方维护关系,至于是用单向还是用 ...

  9. 用泛型创建SqlServerHelper类实现增删改查(一)

    使用泛型,可以构建对数据库单表的基本增删改查. 首先有一数据库 Test_SqlServerHelper ,有2表 接下来创建项目,对数据库进行增删改查. 直接贴代码:(SqlServerHelper ...

随机推荐

  1. Rails 5 Test Prescriptions 第4章 什么制造了伟大的测试

    伴随着程序成长,测试变长,复杂性增加,如何更高效的写测试,对以后开发不会造成麻烦. 测试本身没发被测试,所以一定要清楚,可控.不要加循环,不要过于复杂的自动编程. Cost and Value 成本和 ...

  2. Rspec: everyday-rspec实操: 第10章测试其他功能,第11章TDD 第12章总结。

    10.测试文件上传 作者推荐的Paperclip,官方维护组已经不推荐使用deprecated. 推荐使用rails自带的 ActiveStorage. Active Storage: 推进文件上传到 ...

  3. wikioi1036 商务旅行 挺水的lca

    链接:http://wikioi.com/problem/1036/ 题意不写了. 思路:很明显找到lca然后用两个点的深度相加-lca的深度就是这一步的最近步数. #include <stdi ...

  4. jQuery.prop() 函数详解

    prop()函数用于设置或返回当前jQuery对象所匹配的元素的属性值. 该函数属于jQuery对象(实例).如果需要删除DOM元素的属性,请使用removeProp()函数. 语法jQuery 1. ...

  5. 008PHP文件处理——文件操作r w (用的比较多) a x(用的比较少) 模式 rewind 指针归位:

    <?php /** *文件操作r w (用的比较多) a x(用的比较少) 模式 rewind 指针归位: */ /*$a=fopen('a.txt','r'); echo fread($a,f ...

  6. RabbitMQ的几种工作模式

    maven: <dependencies> <!-- RabbitMQ的客户端 --> <dependency> <groupId>com.rabbit ...

  7. rabbitmq 对多服务器p2p模式配置的一个测试

    一直对rabbitmq p2p 模式的多服务器下做相同配置的 各个服务器数据接受情况比较好奇 今天有空测试了下 xml 文件 <?xml version="1.0" enco ...

  8. FireFox和IE下使用Date来构造新Date对象的BUG

    正常方式 我们都知道可以使用new Date()来创建一个Date对象. new Date();//Date {Mon Jun 15 2015 15:53:16 GMT+0800} 也可以用new D ...

  9. 根据马甲、应用商店、统计每天的注册量,要求可以根据选择马甲和app,马甲和appstrore和user_login不同表问题

    这个马甲属于一个表,appStore另一张表,用户登录表,主要操作的就是这三个表. 我这里的马甲和app的id都与用户登录表中的channel对应,在channel存放的是majiaId + “|” ...

  10. 【转】MongoDB 3.0 正式版本即将发布,强力推荐

    MongoDB 今天宣布3.0 正式版本即将发布.这标志着 MongoDB 数据库进入了一个全新的发展阶段,提供强大.灵活而且易于管理的数据库管理系统. MongoDB 3.0 在性能和伸缩性方面都有 ...