慕课网-Hibernate初探之单表映射 学习
来源:互联网 发布:守望先锋生涯数据消失 编辑:程序博客网 时间:2024/06/07 14:40
先给eclipse安装hibernate插件
打开eclipse工具,选择HELP---Install new software----输入网址
http://download.jboss.org/jbosstools/updates/development
安装Hibernate Tools
初探Hibernate
Students.java
需要
1.参数私有化
2.一个无参构造函数
3.需要所有参数的setter/getter方法
import java.util.Date;public class Students {private int sid;private String sname;private String gender;private Date birthday;private String address;public Students() {super();}public int getSid() {return sid;}public void setSid(int sid) {this.sid = sid;}public String getSname() {return sname;}public void setSname(String sname) {this.sname = sname;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "Students [sid=" + sid + ", sname=" + sname + ", gender=" + gender + ", birthday=" + birthday+ ", address=" + address + "]";}}
hibernate.cfg.xml
原来数据库中没有Students表。不过没关系。
hbm2ddl.auto是create。
意思是每次插入数据前,都要先dop,再create
<?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"><hibernate-configuration> <session-factory> <property name="connection.username">root</property> <property name="connection.password">root</property> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql:///hibernate?useUnicode=true&characterEncoding=UTF-8</property><property name="dialect">org.hibernate.dialect.MySQLDialect</property> <property name="show_sql">true</property> <property name="format_sql">true</property> <property name="hbm2ddl.auto">create</property> <mapping resource="Students.hbm.xml"/> </session-factory></hibernate-configuration>
Students.hbm.xml
这个是自动生成的。
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-4-28 16:17:27 by Hibernate Tools 3.4.0.CR1 --><hibernate-mapping> <class name="Students" table="STUDENTS"> <id name="sid" type="int"> <column name="SID" /> <generator class="assigned" /> </id> <property name="sname" type="java.lang.String"> <column name="SNAME" /> </property> <property name="gender" type="java.lang.String"> <column name="GENDER" /> </property> <property name="birthday" type="java.util.Date"> <column name="BIRTHDAY" /> </property> <property name="address" type="java.lang.String"> <column name="ADDRESS" /> </property> </class></hibernate-mapping>
测试类
import java.util.Date;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.hibernate.service.ServiceRegistry;import org.hibernate.service.ServiceRegistryBuilder;import org.junit.After;import org.junit.Before;import org.junit.Test;public class StudentsTest {private SessionFactory sessionFactory;private Session session;private Transaction transaction;@Beforepublic void init(){//创建配置对象Configuration config = new Configuration().configure();//创建服务注册对象ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry();//创建会话工厂对象sessionFactory = config.buildSessionFactory(serviceRegistry);//会话对象session = sessionFactory.openSession();//开启事务transaction = session.beginTransaction();}@Afterpublic void destory(){//提交事务transaction.commit();//关闭会话session.close();//关闭sessionFactorysessionFactory.close();}@Testpublic void testSaveStudents() {Students s = new Students();s.setSid(3);s.setSname("张三丰");s.setGender("男");s.setBirthday(new Date());s.setAddress("武当山");//保存对象到数据库session.save(s);}}
运行结果
Hibernate: drop table if exists STUDENTSHibernate: create table STUDENTS ( SID integer not null, SNAME varchar(255), GENDER varchar(255), BIRTHDAY datetime, ADDRESS varchar(255), primary key (SID) )Hibernate: insert into STUDENTS (SNAME, GENDER, BIRTHDAY, ADDRESS, SID) values (?, ?, ?, ?, ?)
同时查看数据库,会发现一条记录
2-5 Session详解(上)
注意如果是openSession,需要每次都要手动关闭Session,
如果是getCurrentSession,会自动关闭Session
2-7 hbm配置文档
通常使用的是native。和assigned
3-2.单一主键
3-3.基本类型
xxx.hbm.xml
如果想要“年月日,时分秒”,type="java.util.date"或者type="timestamp"
如果想要“年月日”,type="date"
如果想要“时分秒”,type="time"
注意timestamp,date,time都是hibernate类型
3-4.对象类型
3-5.组件属性
3-6.单表操作CRUD实例
import java.util.Date;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.hibernate.service.ServiceRegistry;import org.hibernate.service.ServiceRegistryBuilder;import org.junit.After;import org.junit.Before;import org.junit.Test;public class StudentsTest {private SessionFactory sessionFactory;private Session session;private Transaction transaction;@Beforepublic void init(){//创建配置对象Configuration config = new Configuration().configure();//创建服务注册对象ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry();//创建会话工厂对象sessionFactory = config.buildSessionFactory(serviceRegistry);//会话对象session = sessionFactory.openSession();//开启事务transaction = session.beginTransaction();}@Afterpublic void destory(){//提交事务transaction.commit();//关闭会话session.close();//关闭sessionFactorysessionFactory.close();}@Testpublic void testSaveStudents() {Students s = new Students();s.setSname("张三丰");s.setGender("男");s.setBirthday(new Date());s.setAddress("武当山");//保存对象到数据库session.save(s);}@Testpublic void testGetStudents(){Students s = (Students)session.get(Students.class, 0);//System.out.println(s);}@Testpublic void testLoadStudents(){Students s = (Students)session.load(Students.class, 0);//System.out.println(s);}@Testpublic void testUpdateStudents(){Students s = (Students)session.get(Students.class, 0);s.setGender("女");session.update(s);System.out.println(s);}@Testpublic void testDeleteStudents(){Students s = (Students)session.get(Students.class, 0);session.delete(s);}}
0 0
- 慕课网-Hibernate初探之单表映射 学习
- 慕课网 hibernate初探之单表映射
- Hibernate初探之单表映射
- Hibernate初探之单表映射
- Hibernate初探之单表映射笔记(1)
- Hibernate初探之单表映射笔记(2)
- Hibernate初探之单表映射笔记(2)
- Hibernate 之单表映射
- Hibrenante初探之单表映射
- hibernate初探之表单映射
- Hibernate学习笔记--单表映射
- Hibernate学习笔记 单表映射
- Hibernate 之单表继承映射策略
- hibernate单表之组件映射和继承映射
- hibernate单表映射
- Hibernate单表映射
- hibernate单表映射
- Hibernate单表映射
- div中嵌套iframe
- EasyAR从入门到精通开发系列教程(4)---脱卡功能总结
- 顺序表操作集
- java基础学习总结——多态(动态绑定)
- td背景颜色渐变
- 慕课网-Hibernate初探之单表映射 学习
- java基础学习总结——对象转型
- 日历上翻一个月一个星期
- java基础学习总结——抽象类
- java基础学习总结——接口
- attr :session,request,application
- bzoj1227: [SDOI2009]虔诚的墓主人
- JavaScript学习总结(六)——JavaScript判断数据类型总结
- s:iterator