j2EE学习之hibernate—连接mysql

从昨天一直到现在终于 连上了,期间有很多波折,出现了好多错误,包括jdbc环境有问题,mysql连不上,到找不到实体类的属性。

先来说一下步骤吧。

1.创建实体类

public class User {
	private int uid;
	private String username;
	private String password;
	private String address;
	public int getUid() {
		return uid;
	}
	public void setUid(int uid) {
		this.uid = uid;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
	public String getAddress() {
		return address;
	}
	public void setAddress(String address) {
		this.address = address;
	}
	
	
	

}

2.映射文件

实体类名称.hbm.xml--->User.hbm.xml,建议在实体类所在包创建.xml文件,也可以右键new一个.hbm.xml文件,.xml文件需要自己加约束hibernate-mapping.dtd

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
<hibernate-mapping>
<!-- 1.配置类和表对应的class标签,
       name属性:实体类全路径 
       table属性:数据库表名称
       -->
   <class name="cn.software.entity.User" table="t_user">
   <!-- 2.配置实体类id和表的id对应
   hibernate要求实体类有一个属性唯一值
   hibernate要求表有字段作为唯一值 -->
   
  <!--  id标签
    name属性:实体类里面id属性名称
    column属性:生成的表字段名称 -->
   <id name="uid" column="uid">
    <!--  设置数据库表id增长策略
     native:生成表id值就是主键自动增长 -->
     <generator class="native"></generator>
   </id>
   <!-- 配置其他属性和表字段对应
   name属性:实体类属性名称
   column属性:生成表字段名称 -->
   <property name="username" column="username"></property>
   <property name="password" column="password"></property>
   <property name="address" column="address"></property>
   </class>
</hibernate-mapping>

 

3.核心配置文件

固定位置,名称,src下面,hibernate.cfg.xml

同样的可以是,xml文件自己加约束,或者直接创建这个文件,约束是hibernate-configuration.dtd

<?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.url">jdbc:mysql://127.0.0.1:3306/hibernate_day01?useUnicode=true&amp;characterEncoding=UTF-8</property>
	<property name="hibernate.connection.username">root</property>
	<property name="hibernate.connection.password">mysql</property>
	<!-- 第二部分:配置hibernate信息 可选 -->
	<!-- 输出底层的sql语句 -->
	<property name="hibernate.show_sql">true</property>
	<!-- 底层的sql语句进行格式化 -->
	<property name="hibernate.format_sql">true</property>
	<!-- hibernate帮创建表,需要配置之后
	 update:如果已经有表,更新,如果没有,创建 -->
	<property name="hibernate.hbm2ddl.auto">update</property>
	<!-- 配置数据库方言
	    在mysql里面实现分页,关键字limit,只能使用mysql里面
	    在oracle数据库,实现分页rownum
	    让hibernate框架识别不同数据库的自己特有的语句
	 -->
	<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
	<!-- 第三部分:把映射文件放到核心配置文件中 -->
	<mapping resource="cn/software/entity/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>

4.测试类

package cn.software.hibernatetest;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;

import cn.software.entity.User;

public class HibernateDemo {
  @Test
  public void testAdd(){
	  //加载hibernate核心配置文件
	     //到src下面去找到名称是hibernate.cfg.xml文件
	     //在hibernate里面封装对象
	  Configuration cfg= new Configuration();
	  cfg.configure();
	  //创建SessionFactory对象
	    //读取hibernate核心配置文件内容,创建SessionFactory
	    //在过程中,根据映射关系,在配置数据库里面把表创建
	  SessionFactory sessionfactory=cfg.buildSessionFactory();
	  //使用SessionFactory创建Session对象,类似于连接
	  Session session=sessionfactory.openSession();
	  //开启事务
	  Transaction tx=session.beginTransaction();
	  //写具体逻辑crud操作
	    //添加功能
	  User user=new User();
	  user.setUsername("小王");
	  user.setPassword("250");
	  user.setAddress("中国");
	    //调用session里的方法实现添加
	  session.save(user);
	  //提交事务
	  tx.commit();
	  //关闭资源
	  session.close();
	  sessionfactory.close();
  }
  
  

 

这里用到了注解Test,Junit测试,需要导入library环境。右键buildpath->addlibrary->junit->finish

5.结果

问题1 :Could not locate field nor getter method for property named [cn.software.entity.Username] 

 

原因是User.hbm.xml文件出现错误,username写错了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值