Hibernate 操作数据库
com.tao.pojo实体类
package com.tao.pojo;
public class User {
private int id;
private String name;
private String password;
public User() {
super();
}
public User(int id, String name, String password) {
super();
this.id = id;
this.name = name;
this.password = password;
}
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 getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", password=" + password + "]";
}
}
User.hbm.xml映射文件
<?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="org.hibernate.test.schemaupdate">
<class name="com.tao.pojo.User" table="user">
<id name="id">
<generator class="identity"></generator>
</id>
<property name="name"/>
<property name="password" column="pass"/>
</class>
</hibernate-mapping>
配置文件hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?>
<!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.mysql.jdbc.Driver</property>
<property name="hibernate.connection.password">root</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test0102?characterEncoding=utf-8</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<!-- 因为加载的时候只加载配置文件,没有加载映射文件,让它去找 -->
<mapping resource="com/tao/pojo/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
DAO方法
com.tao.dao
package com.tao.dao;
import java.util.List;
public interface BaseDAO<T> {
// 通用的功能
public List<T> findAll();
public T findById(int id);
public void deleteById(int id);
public boolean update(T t);
public boolean save(T t);
}
package com.tao.dao;
import com.tao.pojo.User;
public interface UserDAO extends BaseDAO<User> {
public User login(String name,String password);
}
实现类 com.tao.dao.Impl
package com.tao.dao.Impl;
import java.io.Serializable;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.query.Query;
import com.tao.dao.UserDAO;
import com.tao.pojo.User;
public class UserDAOImpl implements UserDAO{
@Override
public List<User> findAll() {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
Query<User> query = session.createQuery("from User", User.class);
List<User> list = query.list();
session.getTransaction().commit();
session.close();
factory.close();
return list;
}
@Override
public User findById(int id) {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
Query<User> query = session.createQuery("from User where id=?", User.class);
query.setParameter(0, id);
User user = query.uniqueResult();
session.getTransaction().commit();
session.close();
factory.close();
return user;
}
@Override
public void deleteById(int id) {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
//方法1
// User user = session.get(User.class, id);
// session.delete(user);
//放法2
// User user = new User();
// user.setId(id);
// session.delete(user);
//方法3
Query query = session.createQuery("delete from User where id=?");
query.setParameter(0, id);
int rows = query.executeUpdate();
System.out.println(rows+"=============rows");
session.getTransaction().commit();
session.close();
factory.close();
}
@Override
public boolean update(User t) {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
//update()只根据Id更新
// session.update(t);
//HQL语句(User是类名,name,password是类里面的属性名)
Query query = session.createQuery("update User set name=?,password=? where id=?");
query.setParameter(0, t.getName());
query.setParameter(1, t.getPassword());
query.setParameter(2, t.getId());
int rows = query.executeUpdate();
session.getTransaction().commit();
session.close();
factory.close();
if(rows>0) {
return true;
}
return false;
}
@Override
public boolean save(User t) {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
Integer id = (Integer) session.save(t);
session.getTransaction().commit();
session.close();
factory.close();
if(id>0) {
return true;
}
return false;
}
@Override
public User login(String name, String password) {
// TODO Auto-generated method stub
Configuration configure = new Configuration().configure();
SessionFactory factory = configure.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
Query<User> query = session.createQuery("from User where name=? and password=?",User.class);
query.setParameter(0, name).setParameter(1, password);
User user = query.uniqueResult();
session.getTransaction().commit();
session.close();
factory.close();
return user;
}
}
JUnit测试
package com.tao.test;
import static org.junit.Assert.*;
import java.util.List;
import org.junit.Test;
import com.tao.dao.Impl.UserDAOImpl;
import com.tao.pojo.User;
public class JUnit_User {
UserDAOImpl impl = new UserDAOImpl();
@Test
public void testAll() {
List<User> list = impl.findAll();
for (User uu : list) {
System.out.println(uu);
}
}
@Test
public void testById() {
User user = impl.findById(2);
System.out.println(user);
}
@Test
public void testdeleteById() {
System.out.println("delete++++++++++++++++++");
impl.deleteById(10);
}
@Test
public void save() {
User user = new User(12, "ss", "ss");
boolean b = impl.save(user);
System.out.println(b);
}
@Test
public void update() {
User user = new User(2, "ss", "222");
impl.update(user);
}
//登录
@Test
public void login() {
User user = impl.login("ss", "222");
System.out.println(user);
}
}
Hibernate 操作数据库的更多相关文章
- hibernate操作数据库总结
这篇文章用于总结hibernate操作数据库的各种方法 一.query方式 1.hibernate使用原生态的sql语句执行数据库查询 有些时候有些开发人员总觉得用hql语句不踏实,程序出现了错误,就 ...
- Java_Web三大框架之Hibernate操作数据库(三)
使用Hibernate操作数据库需要七个步骤: (1)读取并解析配置文件 Configuration conf = newConfiguration().configure(); (2)读取并解析映射 ...
- hibernate操作数据库例子
1.工程目录结构如下 2.引入需要的jar包,如上图. 3.创建持久化类User对应数据库中的user表 package com.hibernate.配置文件.pojo; import java.sq ...
- hibernate操作数据库总结(转)
一.query方式 1.hibernate使用原生态的sql语句执行数据库查询 有些时候有些开发人员总觉得用hql语句不踏实,程序出现了错误,就猜测因为不是原生态的sql语句,数据库不支持,因此情愿选 ...
- Hibernate操作数据库的回调机制--Callback
1:一般情况下,在使用Hibernate Session存取数据库的代码中,基本上大部分是相同的,如下两个方法所示, //查询Teacher操作 ublic Teacher getTeacher ...
- 转 使用Hibernate操作数据库时报:No CurrentSessionContext configured! 异常
没有currentSession配置错误,即在我们使用currentSession的时候要在hibernate.cfg.xml中进行相关的事务配置:1.本地事务<property name=&q ...
- hibernate操作数据库时报错解决方式
java.sql.SQLException: Parameter index out of range (28 > number of parameters, which is 27). 这个说 ...
- Spring MVC基础知识整理➣Spring+SpringMVC+Hibernate整合操作数据库
概述 Hibernate是一款优秀的ORM框架,能够连接并操作数据库,包括保存和修改数据.Spring MVC是Java的web框架,能够将Hibernate集成进去,完成数据的CRUD.Hibern ...
- 5 -- Hibernate的基本用法 --2 2 Hibernate的数据库操作
在所有的ORM框架中有一个非常重要的媒介 : PO(持久化对象:Persistent Object).持久化对象的作用是完成持久化操作,简单地说,通过该对象可对数据执行增.删.改的操作 ------ ...
随机推荐
- Android开发 PopupWindow弹窗调用第三方地图(百度,高德)实现导航功能
博客描述:后台返回地点的经纬度在地图上进行描点,点击导航弹出PopupWindow进行选择地图操作,如果手机中没有安装地图,提示没有,否则传值调起地图进行导航操作 看一下实现的效果,没图说再多都白搭 ...
- sort list(给链表排序)
Sort a linked list in O(n log n) time using constant space complexity. 题目要求使用O(nlogn)时间复杂度,可以考虑使用归并排 ...
- 排序算法入门之希尔排序(java实现)
希尔排序是对插入排序的改进.插入排序是前面元素已经有序了,移动元素是一个一个一次往后移动,当插入的元素比前面排好序的所有元素都小时,则需要将前面所有元素都往后移动.希尔排序有了自己的增量,可以理解为插 ...
- SQLServer中PRECISION和LENGTH,还有SCALE的区别
总是搞不清楚,每次自己测试之后又忘记.故今天记录在案 CST_NAME输入大于5个字符或两个汉字加一个字符,报错String or binary data would be truncated.The ...
- 关于Android适配华为等带有底部虚拟按键的解决方案
http://blog.csdn.NET/a91694451/article/details/50469857 最近公司的项目里遇到了一个问题,就是最后适配的时候时候同事的华为手机时,由于底部带有虚拟 ...
- Ubuntu 14.10下基于Nginx搭建mp4/flv流媒体服务器(可随意拖动)并支持RTMP/HLS协议(含转码工具)
Ubuntu 14.10下基于Nginx搭建mp4/flv流媒体服务器(可随意拖动)并支持RTMP/HLS协议(含转码工具) 最近因为项目关系,收朋友之托,想制作秀场网站,但是因为之前一直没有涉及到这 ...
- hadoop配置文件详解系列(二)-hdfs-site.xml篇
上一篇介绍了core-site.xml的配置,本篇继续介绍hdfs-site.xml的配置. 属性名称 属性值 描述 hadoop.hdfs.configuration.version 1 配置文件的 ...
- 搭建centos7的开发环境2-单机版Hadoop2.7.3配置
最近公司准备升级spark环境,主要原因是生产环境的spark和hadoop版本都比较低,但是具体升级到何种版本还不确定,需要做进一步的测试分析.这个任务对于大数据开发环境配置有要求,这里记录一下配置 ...
- Coursera-AndrewNg(吴恩达)机器学习笔记——第三周编程作业
一. 逻辑回归 1.背景:使用逻辑回归预测学生是否会被大学录取. 2.首先对数据进行可视化,代码如下: pos = find(y==); %找到通过学生的序号向量 neg = find(y==); % ...
- [Kali_Metasploit]db_connect创建连接时无法连接的解决方案
问题1复现路径: postgresql selected, no connection 第一步: db_connect postgres:toor@127.0.0.1/msfbook 连接成功不需要进 ...