myeclipse开发hibernate应用程序示例

本文详细介绍如何利用Hibernate框架在MyEclipse环境下搭建一个学生信息管理的小程序,涵盖数据库搭建、环境配置、代码编写等全过程。

今天看了hibernate持久层的概述,就用myeclipse试着动手开发了一个简单的学生信息管理小程序。

在开发之前,先要理解一个概念ORMORMobject-relation mapping)是对象关系映射,对象指的是java中的对象,关系是指关系型数据库,ORM也就是指从Java对象到数据库之间的映射,也就是通过一个类的操作来代表数据库中的操作。而Hibernate是一个ORM的实现,所以,主要功能就是操作数据库(以对象的形式操作数据库)。

ORM模式图如下:

本人运用的开发环境为:Eclipse3.2.1+MyEclipse5.1集成开发环境,数据库为MySQL4.01版本。

下面开始动手吧……
S1创建数据库,数据库脚本如下:

create database hibernate;
use hibernate;
create table Student
(
      id varchar(32) not null primary key,
      sName varchar(20) not null,
      sNO varchar(20) not null,
      sex varchar(2),  
      email varchar(30)
);

S2:配置MyEclipse环境,使之能够生成HBM文件,即Hibernate映射文件,过程如下:

配置MySQL驱动程序:

Eclipse中,点击Window ->Preferences->MyEclipse -> Database Explorer -> Drivers -> New…

选择Driver template 为:MySQL Connector/J

URL: jdbc:mysql://localhost:3306/hibernate,其中hibernate为数据库名称;

添加MySQL驱动:mysql"lib"mysqldriver.jar,点击 OK

现在只是配置好数据库的环境,但是还没有真正的生成它,还要创建Database Profile方法如下:

打开Window -> Open Perspective->MyEclipse Database Explorer

选择其中的New 图标,上面那个是我以前做过的,因此在新建一个。


Profile name 由自己来定,我定为JDBC for MySQLDriver 就是选由上面刚刚配置过的

MySQL Connector/J,点击Next -> Finish


右键刚刚创建的JDBC for MySQL2,打开Open connection…


出现了我们刚刚创建的数据库student,好了,可以松一口气了,暂时先放一放,后面还会用到这个界面的,在打开Window -> Open Perspective->Java界面。

S3新建一个J2EEWeb Project ,工程名为StuHibernate

然后给这个项目添加hibernate必要的文件.在我们项目名上点击右键,选择MyEclipes --> Add Hibernate Capabilities...弹出对话框如下图:


其中,JAR Library Installation 选为 Copy checked Library Jars to Project …项,其它项均为默认,点击Next,进入下一个页面后,继续点击Next,进入第三个页面


选择 DB Profile 文件JDBC for MySQL,就是我们在S2步骤中配置的数据库驱动,在这里,我们就什么也不用手动添写了,直接生成,这就是S2步骤的好处,其中数据库的言也选为MySQL,点击Next进入下一页面

取消对Crate SessionFactory class? 选项的选择,点击Finish。项目结构如下图:


 src 目录下产生了一个hibernate.cfg.xml 文件:主要是对Hibernate环境配置的,包括使用的数据库或数据源。Eclipse为此提供了图形环境配置,配置方法为在S2步骤中以配置好了,因此直接生成了如下页面:


其中本人数据库密码为空,因此什么都没有写。由于MySQL数据库驱动以经加了WEB-INF/lib文件夹中,上面的图中以有显示。如果没有加入,则复制到里面。一切准备工作都以就绪,下面我们就开始真正的编写代码了!(终于写到一半了,好累啊,呵呵)

S4编写POJO类,也就是持久化类:只包含settergetter方法的类。POJOPlain Old Java Objects)是最普通的Java对象,很像JavaBean。类名最好和表名相同,开头最好大写,Student.java


包名:com.cc.hibernate

类名:Student

代码如下:

package com.cc.hibernate;
//POJO类
public class Student {
   //写入若干属性
    private String id;
    private String sname;
    private String sno;
    private String sex;
    private String email;
    public String getEmail() {
       return email;
    }
    public void setEmail(String email) {
       this.email = email;
    }
    public String getId() {
       return id;
    }
    public void setId(String id) {
       this.id = id;
    }
    public String getSex() {
       return sex;
    }

    public void setSex(String sex) {
       this.sex = sex;
    }

    public String getSname() {
       return sname;
    }

    public void setSname(String sname) {
       this.sname = sname;
    }

    public String getSno() {
       return sno;
    }

    public void setSno(String sno) {
       this.sno = sno;
    }
}

S5建立映射文件,在次打开Window -> Open Perspective->MyEclipse Database Explorer,接到S2步骤


右键点击student表,打开Hibernate Reverse Engineering…

创建到包含有POJO类包的文件夹下:

点击 Next,进入下一页面


Type Mapping Hibernate types

主键生成方式选为 assigned(指派),由用户自行完成,单击 Next,最后点击 Finish

在次切回 Window -> Open Perspective->Java界面,出现 Student.hbm.xml映射文件,双击打开查看其代码。

此文件完成Student类到student表的关系

S6编写具体类,具体操作Hibernate 方法,在Com.cc.hibernate包下

新建类 StudentOperate.java

package com.cc.hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.Transaction;
public class StudentOperate {
    //在Hibernate中,所有的操作都是通过Session完成
    //此Session不同于JSP的Session
    private Session session=null;
    //在构造方法之中实例化session对象
    public StudentOperate(){
       // 找到Hibernate配置
       Configuration config=new Configuration().configure();
       //从配置中取出SessionFactory
       SessionFactory factory=config.buildSessionFactory();
       //从SessionFactory中取出一个Session
       this.session=factory.openSession();
    }

   

    //所有操作都是由session进行的
    //向数据库中增加数据
    public void insert(Student student){
       //开始事务
       Transaction tran=this.session.beginTransaction();

       //执行语句
       this.session.save(student);

       //提交事务
       tran.commit();
    }
}

S7com.cc.hibernate 包下新建一个测试类 StudentTest.java

代码如下:

package com.cc.hibernate;
public class StudentTest {
    public static void main(String[] args) {
       // TODO Auto-generated method stub
       //生成POJO类实例化对象
       Student stu=new Student();
       stu.setId("006");
       stu.setSname("chen");
       stu.setSno("03170217");
       stu.setSex("男");
       stu.setEmail("chenchuang.sy@163.com");

       //实例化 StudentOperate 对象
       StudentOperate op=new StudentOperate();
       op.insert(stu);
    }
}

运行后的页面为:

再次查看数据库,看是否添加成功。

如果希望看见所执行的SQL语句,打开hibernate.cfg.xml文件

点击 Add按钮后,出现如下页面:


选择Propertyshow_sql,设置Valueture,点击OK

运行后的界面为:


若出现以下问题:

java.lang.AbstractMethodError: com.microsoft.jdbc.base.BaseDatabaseMetaData.supportsGetGeneratedKeys()Z 

log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
Exception in thread "main" java.lang.AbstractMethodError: com.microsoft.jdbc.base.BaseDatabaseMetaData.supportsGetGeneratedKeys()Z
 at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:123)
 at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2119)
 at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2115)
 at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1339)
 at dao.HibernateSessionFactory.<clinit>(HibernateSessionFactory.java:31)
 at dao.BaseHibernateDAO.getSession(BaseHibernateDAO.java:13)
 at HibernateDAOTest.main(HibernateDAOTest.java:16)

解决:microsoft提供的数据库驱动存在bug。需要换一种驱动连接,使用jtds(下载地址:http://sourceforge.net/projects/jtds/files/)下载jtds1.2版,解压得到jtds-1.2.jar,引用到eclipse中项目目录下(去除原驱动引用),更改hibernate配置文件:

原驱动连接配置:

 <property name="connection.driver_class">com.microsoft.jdbc.sqlserver.SQLServerDriver</property>
        <property name="connection.url">jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=hibernate</property>
更改jtds连接:   
        <property name="connection.driver_class">net.sourceforge.jtds.jdbc.Driver</property>
        <property name="connection.url">jdbc:jtds:sqlserver://127.0.0.1:1433;DatabaseName=hibernate</property>

问题得到解决。补充:java代码调原驱动连接数据库是没有问题的,搭配hibernate会有此问题。


在连接mysql5.1时正常,连接sql2000时就是连不上,郁闷,终于在网上找到了解答,原来是sql驱动和hibernate的兼容性问题,现问题已解决,留此文备查.



数据集介绍:电力线目标检测数据集 一、基础信息 数据集名称:电力线目标检测数据集 图片数量: 训练集:2898张图片 验证集:263张图片 测试集:138张图片 总计:3299张图片 分类类别: 类别ID: 0(电力线) 标注格式: YOLO格式,包含对象标注信息,适用于目标检测任务。 数据格式:JPEG/PNG图片,来源于空中拍摄或监控视觉。 二、适用场景 电力设施监控与巡检: 数据集支持目标检测任务,帮助构建能够自动识别和定位电力线的AI模型,用于无人机或固定摄像头巡检,提升电力设施维护效率和安全性。 能源与公用事业管理: 集成至能源管理系统中,提供实时电力线检测功能,辅助进行风险 assessment 和预防性维护,优化能源分配。 计算机视觉算法研究: 支持目标检测技术在特定领域的应用研究,促进AI在能源和公用事业行业的创新与发展。 专业培训与教育: 数据集可用于电力行业培训课程,作为工程师和技术人员学习电力线检测与识别的重要资源。 三、数据集优势 标注精准可靠: 每张图片均经过专业标注,确保电力线对象的定位准确,适用于高精度模型训练。 数据多样性丰富: 包含多种环境下的电力线图片,如空中视角,覆盖不同场景条件,提升模型的泛化能力和鲁棒性。 任务适配性强: 标注格式兼容YOLO等主流深度学习框架,便于快速集成和模型开发,支持目标检测任务的直接应用。 实用价值突出: 专注于电力线检测,为智能电网、自动化巡检和能源设施监控提供关键数据支撑,具有较高的行业应用价值。
【弹簧阻尼器】基于卡尔曼滤波弹簧质量阻尼器系统噪声测量实时状态估计研究(Matlab代码实现)内容概要:本文围绕“基于卡尔曼滤波的弹簧质量阻尼器系统噪声测量与实时状态估计”展开研究,利用Matlab代码实现对系统状态的精确估计。重点在于应用卡尔曼滤波技术处理系统中存在的噪声干扰,提升对弹簧质量阻尼器系统动态行为的实时观测能力。文中详细阐述了系统建模、噪声特性分析及卡尔曼滤波算法的设计与实现过程,展示了滤波算法在抑制测量噪声、提高状态估计精度方面的有效性。同时,该研究属于更广泛的信号处理与状态估计技术应用范畴,适用于复杂动态系统的监控与控制。; 适合人群:具备一定控制系统理论基础和Matlab编程经验的高校研究生、科研人员及工程技术人员,尤其适合从事动态系统建模、状态估计与滤波算法研究的相关人员。; 使用场景及目标:①应用于机械、航空航天、自动化等领域中对振动系统状态的高精度实时估计;②为噪声环境下的传感器数据融合与状态预测提供算法支持;③作为卡尔曼滤波算法在实际物理系统中应用的教学与科研案例。; 阅读建议:建议读者结合Matlab代码实践,深入理解系统建模与滤波器设计的关键步骤,关注噪声建模与滤波参数调优对估计性能的影响,并可进一步拓展至扩展卡尔曼滤波(EKF)或无迹卡尔曼滤波(UKF)在非线性系统中的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值