一、首先先建立一个Web Project

二、然后在程序根目录建立文件夹“DataBase”和“Doc”,分别存放数据库文件和保存SQL语句,建完如下所示:

三、建立数据库“dbHibernate”,保存到文件夹“DataBase”下

四、书写SQL语句,创建“student”表

-- 数据库名称  dbHibernate

-- 版本        SQLServer2008

--学生表

create table student(

ID varchar(10) primary key,

Name varchar(20) not null,

)

--插入数据

insert into student values('101','张三');

insert into student values('102','李四');

insert into student values('103','王五');

五、打开“DB Browser”后,右击选择“New...”,Driver template选择“Microsoft SQL Server”,Driver name为“Hibernate”,Connection URL为“jdbc:sqlserver://localhost:1433; DatabaseName=dbHibernate”,然后就是数据库的User name以及Password;还要添加“sqljdbc4.jar”驱动包,点击“Test Driver”,可以看到测试成功

六、然后点击“Next”,选择“Display the selected schemas”,点击“Add”添加数据库“dbHibernate”,最后“Finish”。

七、右击项目“Hibernate”->“Myeclipse”->“Add Hibernate Capabilities...”,然后默认点击“Next”

八、选择“Browse”,添加自己建立的包名,然后“Next”后,选择“DB Driver”下的“Hibernate”,下面的内容将自动调出。然后“Next”,选择“Java package”

九、建完后,在包“com.langguojie.Hibernate”下添加了“HibernateSessionFactory.java”以及“hibernate.cfg.xml”两个文件

十、在“DB Browser”下,选择“Hibernate”->“Open connection”->Connected to Hibernate->dbo->TABLE->student,右击选择“Hibernate Reverse Engineering”

十一、选择 Java package:“com.langguojie.Hibernate.orm”,然后选择如下图所示内容,点击“Finish”即可。

十二、在包“com.langguojie.Hibernate.orm”下添加了“Student.java”和“Student.hbm.xml”两个文件

十三、在index.jsp中添加如下代码:

<%@page import="com.langguojie.Hibernate.orm.Student"%>
<%@page import="org.hibernate.Query"%>
<%@page import="com.langguojie.Hibernate.HibernateSessionFactory"%>
<%@page import="org.hibernate.Session"%>
<center>
学生管理<br>
<br>
<a href="StudentAdd.html">添加</a><br>
<br>
<table border="1" cellspacing="0" cellpadding="4">
<%
Session ss = HibernateSessionFactory.getSession(); //建立Session对象ss
ss.beginTransaction(); //打开Transaction Query query=ss.createQuery("from Student"); //调用函数Query查询 List<Student>studentList = new ArrayList<Student>(); //将查询的结果放到List表中
studentList = query.list();
for(int i = 0 ;i < studentList.size();i++){
%> <tr>
<td><%=studentList.get(i).getId()%></td> <!-- 输出ID -->
<td><%=studentList.get(i).getName()%></td> <!-- 输出姓名 -->
<td><a href='StudentEdit.jsp?ID=<%=studentList.get(i).getId()%>'>修改</a>
</td>
<td><a href='servlet/StudentDelete.do?ID=<%=studentList.get(i).getId()%>'>删除</a>
</td>
</tr> <%
}
ss.close(); //关闭Transaction
%>
</table>
</center>

十四、建立添加页面“StudentAdd.html”,代码如下:

 <form id="form1" name="form1" method="post"action="servlet/StudentAdd.do">
<center>添加<br><br>
学号:<input type="text" id="ID" name="ID"><br><br>
姓名:<input type="text" id="Name" name="Name" ><br><br>
<input type="submit" value="确定"></center>
</form>

十五、建立servlet“StudentAdd.java”,使用函数“doPost()”代码如下:

request.setCharacterEncoding("UTF-8");
String strID = "";
String strName = ""; strID = request.getParameter("ID"); //获取ID
strName = request.getParameter("Name"); //获取Name Session ss = HibernateSessionFactory.getSession();
ss.beginTransaction();
Student s = new Student();
s.setId(strID);
s.setName(strName);
ss.save(s); //保存数据
ss.getTransaction().commit(); //提交数据
ss.close(); response.sendRedirect("../index.jsp");

十六、建立编辑页面“StudentEdit.jsp”,代码如下:

<%@page import="com.langguojie.Hibernate.orm.Student"%>
<%@page import="com.langguojie.Hibernate.HibernateSessionFactory"%>
<%@page import="org.hibernate.Session"%>
<%
request.setCharacterEncoding("UTF-8");
String strID=""; strID = request.getParameter("ID"); Session ss = HibernateSessionFactory.getSession();
ss.beginTransaction();
Student student = (Student)ss.get(Student.class, strID); ss.getTransaction().commit();
ss.close();
%>
<center> <%if(student != null){ %> <br><br>编辑学生信息<br>
<form name="f1" id="f1" action="servlet/StudentEdit.do" method="post">
<table border="0">
<tr>
<td>学号:</td>
<td><input type="text" readonly="readonly" name="ID" id="ID" value="<%=student.getId() %>"> 学号不允许编辑</td>
</tr> <tr>
<td>姓名:</td>
<td><input type="text" name="Name" id="Name" value="<%=student.getName() %>"></td>
</tr> <tr>
<td colspan="2" align="center"><input type="submit" value=" 确定 " ></td>
</tr> </table>
</form>
<%} else { %>
<br><br>编辑学生信息<br><br>
学号为<%=strID %>的学生数据在数据库中不存在!<br><br>
<a href="index.jsp">返回</a>
<%} %>
</center>

十七、建立servlet“StudentEdit.java”,使用函数“doPost()”,代码如下:

request.setCharacterEncoding("utf-8");
String strID = "";
String strName = ""; strID = request.getParameter("ID");
strName = request.getParameter("Name"); Session session = HibernateSessionFactory.getSession();
session.beginTransaction();
Student student = (Student)session.load(Student.class, strID);
student.setName(strName); session.update(student); session.getTransaction().commit();
session.close(); response.sendRedirect("../index.jsp");

十八、建立servle“StudentDelete.java”,使用函数“doGet()”,代码如下:

request.setCharacterEncoding("UTF-8");
String strID=""; strID = request.getParameter("ID"); Session ss = HibernateSessionFactory.getSession();
ss.beginTransaction(); Student student = (Student)ss.load(Student.class, strID);
ss.delete(student); ss.getTransaction().commit();
ss.close(); response.sendRedirect("../index.jsp");

十九、运行结果截图:

JSP利用Hibernate实现对数据库的CRUD ——开发环境Myeclipse与SQL Server 2008的更多相关文章

  1. 使用MyEclipse中servlet对SQL Server 2008的CRUD

    1.在MyEclipse下建立Web Project,找到根目录建立Database文件夹和Doc文件夹,Database用于保存数据库信息,Doc用于保存数据库表信息. 2.打开SQL Server ...

  2. 配置MyEclipse+Hibernate连接Sql Server 2008出错

    下文主要是讲述最近配置MyEclipse连接Sql Server 2008时遇到的一个问题,而不关注如何配置Sql Server 2008支持TCP/IP连接.Hibernate如何操作Sql Ser ...

  3. [转]实战 SQL Server 2008 数据库误删除数据的恢复

    实战 SQL Server 2008 数据库误删除数据的恢复 关键字:SQL Server 2008, recover deleted records 今天有个朋友很着急地打电话给我,他用delete ...

  4. 小程序原理,生成SQL SERVER 2008 数据库所有表的结构文档

    作者:wide288 , 日期:2013-7-31 以前开发中,用 MYSQL 数据库,有个小程序 生成数据库结构文档.很方便,做为开发组的文档很有用. 现在开发中用到了 SQL SERVER 200 ...

  5. [转]在 SQL Server 2008 中新建用户登录并指定该用户的数据库

    提要:我在 SQL Server 中新建用户登录时,出现了三种错误,错误代码分别是 18456.15128.4064 -----------------------------------  正 文 ...

  6. 数据库备份和恢复秩序的关系(周围环境:Microsoft SQL Server 2008 R2)

    让我们来看看在备份序列新手 --1.塔建环境(生成测试数据和备份文件) /* 測试环境: Microsoft SQL Server 2008 R2 (RTM) - 10.50.1600.1 (X64) ...

  7. 基于Sql Server 2008的分布式数据库的实践(一)

    原文 基于Sql Server 2008的分布式数据库的实践(一) 配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选 ...

  8. 【转载】SQL Server 2008 中新建用户登录并指定该用户的数据库

    提要:我在 SQL Server 中新建用户登录时,出现了三种错误,错误代码分别是 18456.15128.4064 -----------------------------------  正 文 ...

  9. 【数据库】Sql Server 2008完全卸载方法(其他版本类似)

    本文介绍如何卸载 Microsoft SQL Server 2008的方法.当您按照本文中的步骤时,您还准备系统以便可以重新安装 SQL Server 2008版本 一.    SQL2008卸载. ...

随机推荐

  1. CentOS On VirtualBox

    背景 后台开发需要随时与服务器交互,本人使用Mac开发.但是不愿意在Mac上直接安装redis以及mysql等等工具.所以选择在VirtualenvBox下安装一个服务器系统,并且使用ssh与其连接. ...

  2. 通知:逆天异常库 V1.0版本支持下载了~~

    百度网盘:http://pan.baidu.com/s/1bongheJ GitHub:https://github.com/dunitian/LoTDotNet

  3. 【WP开发】不同客户端之间传输加密数据

    在上一篇文章中,曾说好本次将提供一个客户端之间传输加密数据的例子.前些天就打算写了,只是因一些人类科技无法预知的事情发生,故拖到今天. 本示例没什么技术含量,也没什么亮点,Bug林立,只不过提供给有需 ...

  4. Spring(四)注解配置Ioc

    原文链接:http://www.orlion.ga/216/ 一.@Autowired beans.xml配置成如下: <?xml version="1.0" encodin ...

  5. 手把手教你用nodejs+SQL Server2012做增删改查

    1.开发工具WebStorm 10.0.4 2.打开WebStorm 10.0.4新建项目:

  6. javascript运动系列第七篇——鼠标跟随运动

    × 目录 [1]眼球转动 [2]苹果菜单[3]方向跟随 前面的话 运动除了直线运动和曲线运动两种运动形式外,还有一种运动形式是鼠标跟随运动,而这种跟随运动需要用到三角函数的相关内容或者需要进行比例运算 ...

  7. Android之控件使用

    Android系统为我们提供了大量的控件,例如:开关控件.单选按钮.多选按钮.单选菜单等等,那么这些控件如何使用呢?本篇我将带领大家一道学习一下如何使用这些控件.所谓无图无真相,先让大家看一下效果图: ...

  8. android模拟器默认位置的修改

    1.创建ANDROID_SDK_HOME环境变量,如ANDROID_SDK_HOME=D:\eclipse_android\android-sdk 2.在ANDROID_SDK_HOME目录下,建立. ...

  9. .NET平台开源项目速览(9)软件序列号生成组件SoftwareProtector介绍与使用

    在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Software Protector序列号生成组件.今天就通过一篇简单的文章来预览一下其强大的功 ...

  10. 【开源】OSharp3.3框架解说系列:重新开源及3.3版本新特性

    OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...