`
Sunshyfangtian
  • 浏览: 228645 次
  • 性别: Icon_minigender_1
  • 来自: 惠州
社区版块
存档分类
最新评论

Hibernate连接SQLServer2000数据库(例子)

    博客分类:
  • SSH
阅读更多

 

先从例子开始(使用MyEclipse):

    建立一个Java工程,名为HibernateProject,右击工程名---->Build Path---->Add Libraries--->MyEclipse Libraries(点击“next”)--->选择需要的Hibernate包,我不知道哪些需要,哪些不需要,所以3.2版本的三个包全部添加了,另外还添加了SQLServer的三个驱动包(msbase.jar等放在自己建立的包SqlDriver中)

(1)建立数据库db_Hibernate,然后在查询分析其中在该数据库的基础上建立表login:

create table login
(
    id int identity primary key not null,
    name varchar(15),
    password varchar(15)
)

上面的identity不能少,否则程序运行时会报错,无法插入数据。

  (2)  编写类文件UserInfo.java

package hibernate.ch01;

public class UserInfo {
 private Integer id;
 private String userName;
 private String password;
 public Integer getId() {
  return id;
 }
 public void setId(Integer id) {
  this.id = id;
 }
 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;
 }
 }

保存后在工程的src文件夹下就生成了包hibernate.ch01(目录结构见截图)

Hibernate连接SQLServer2000数据库(例子) - jingfang_1985 - 狂风

  (3) 编写对象关系映射文件UserInfo.hbm.xml(注意开头三行与下面配置文件hibernate.cfg.xml开头的不同):

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC "-//hibernate/Hibernate Mapping DTD 3.0//EN"
                    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- created by afuer -->
   <!-- 类和表之间的关联 -->
   <class name="hibernate.ch01.UserInfo" table="login">
       <!-- 类对象的主键和表主键的关联 -->
       <id name="id" type="integer"><column name="id"/>
       <!-- 指明主键的自增长类型 -->
       <generator class="identity"/>
       </id>
       <!-- 以下为普通字段关联 -->
       <property name="userName" type="string">
           <column name="name" length="100"/>
       </property>
       <property name="password" type="string">
       <column name="password"  length="100"/>
       </property>
   </class>
</hibernate-mapping>

(4)编写配置文件hibernate.cfg.xml(此文件一定是在src目录下):

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <!-- SessionFactory配置 -->
<session-factory>
 <!-- 指定数据库使用的SQL方言 -->
 <property name="hibernate.dialect">
  org.hibernate.dialect.SQLServerDialect
 </property>
 <!-- 指定连接数据库的驱动 -->
 <property name="connection.driver_class">
  com.microsoft.jdbc.sqlserver.SQLServerDriver
 </property>
 <!-- 指定连接数据库的路径 -->
 <property name="connection.url">
  jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=db_Hibernate
 </property>
 <!-- 指定连接数据库的用户名 -->
 <property name="connection.username">sa</property>
 <!-- 指定连接数据库的密码 -->
 <property name="connection.password"></property>
 <!-- 当show_sql属性为true时,表示当程序运行时在控制台输出SQL语句,默认为false -->
 <property name="show_sql">true</property>
 <!-- 指定是否按照标准格式在控制台输出SQL语句 -->
 <property name="format_sql">true</property>
 <!-- 指定是否在SQL语句中输出便于调试的注释信息 -->
 <property name="use_sql_commnets">true</property>
 <!-- 指定持久化类映射文件 -->
 <property name="myeclipse.connection.profile">SqlDriver</property>
 <property name="dialect">
  org.hibernate.dialect.SQLServerDialect
 </property>
 <mapping resource="hibernate/ch01/UserInfo.hbm.xml" />
</session-factory>
</hibernate-configuration>

编写运行测试类HibernateTest.java

package hibernate.ch01;

import hibernate.ch01.UserInfo;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

public class HibernateTest {
 public static void main(String[] args) {
  //加载配置文件'
  SessionFactory sessions=new Configuration().configure().buildSessionFactory();
  Session session=sessions.openSession();
  Transaction tx=null;
  try{
   //开始事务
      tx=session.beginTransaction();
      //给对象设定值
      UserInfo u=new UserInfo();
      u.setUserName("Tracy");
      u.setPassword("123");
      System.out.println("开始插入到数据库...");
      //保存到数据库
      session.save(u);
      //从持久化类UserInfo中读取数据
      UserInfo u1=(UserInfo)session.load(UserInfo.class,new Integer(2));
      System.out.println("从数据库加载数据的用户名为"+u1.getUserName());
      //结束事务
      tx.commit();
      tx=null;
      System.out.println("嗨!恭喜你第一个程序运行成功!");
  }catch(HibernateException e){
   e.printStackTrace();
   if(tx!=null){
    tx.rollback();
   }
  }finally{
   session.close();
  }
 }
}

(5)运行结果截图

Hibernate连接SQLServer2000数据库(例子) - jingfang_1985 - 狂风

 

分享到:
评论

相关推荐

    sqlserver的hibernate

    最容易入门的hibernate操作sqlServer数据库例子

    hibernate3.0例子源码

    hibernate3.0连接SQLServer代码简单例子,单表t_user例子,可以运行。 数据库表设计 CREATE TABLE [dbo].[t_user]( [t_id] [nvarchar](50) NOT NULL, [t_login_name] [nvarchar](50) NULL, [t_password] ...

    struts+hibernate增加用户的简单例子,很适合初学者

    这些天我们学习hibernate,我亲自做的一个struts+hibernate的简单例子。 数据库用的是sqlserver 数据库名字是lhyz 表为USERS 字段有UID(PK) USERNAME PASSWORD

    一树形例子

    这是采用struts+hibernate作的一树形例子,这最大的特点就是,从后面读出数据时,是采用...这例子上,只自带了一Oracle的,数据结构,你可以根据自已的需求,改成自已的数据库的表结构,如Mysql,sqlserver2000......

    欣想电子城-一个J2EE开发的项目例子

    这个是我的这本书&lt;项目开发全程实录丛书系列&gt;光盘上的一个项目例子,里面采用spring+hibernate框架和采用sqlserver2000数据库开发的一个项目,想学J2EE开发的人可以看看!

    基于ssh架构的学生信息管理系统

    基于ssh架构的学生信息管理系统,内打包...使用tomcat 作为web服务器,sqlserver2000数据库.,工程内含有简表语句,默认管理员账号见sadmin.sql 文件内(可自行更改)。部署后如有疑问可到我空间留言,我尽力帮大家解决。

    Hibernate3入门例子

    本例子适合初学者使用 1、myeclipse6+Tomcat6+Sqlserver2005 2、使用先倒入数据库脚本。

    struts1.2_hibernate3.2+spring2.5

    struts1.2_hibernate3.2+spring2.5三大框架整合,简单的来接sqlserver2005数据库,给初学者,压缩包中有创建数据库的sql语句,本例子只做了简单的添加和删除

    Struts+Spring+Hibernate的小例子

    Struts+Spring+Hibernate的小例子,实现图书的添加功能。数据库使用的sqlserver2005

    ssh课堂例子

    从今天开始,许老师所上传的资源除非特别重要,否则一律不要资源积分,推广IT技术是我们做老师...运行环境是 ECLIPSE3.3+TOMCAT5.5+SQLSERVER2000,数据库的脚本在里面。大家下载了之后只需要导入相关JAR包即可学习。

    使用hibernate search实现全文检索和文档管理的例子

    使用hibernate search实现全文检索和文档管理...1 需要先恢复数据库 searchDB_2008sqlserver.bak 2 建立upload目录 本例子在 E:\Tomcat50\upload 3 注意参数正确配置在 hibernate-search\src\applicationContext.xml

    struts hibernate spring 搞定分布式事务

    自动生成表:具体数据库 sqlserver2000 ,oracle 服务层代码如下: public class HibernateServerImpl implements HibernateServerInterface { @Resource private OracleDAOInterface HibernateByOracleDAO; @...

    jsf hibernate tiles 整合登录

    JSF 框架整合hibernate tiles 登录例子,完善整合,数据库采用SQL Server Management Studio Express。

    struts1.2.9+hibernate3框架开发的WEB应用程序(小单位新闻发布系统)

    适合小单位应用的新闻发布系统采用 sql server2000数据库系统,也可以作为教学的小例子。系统只需要初始化管理员数据库,用户信息,新闻版块,及用户权限,由管理员登陆后初始化。登陆用户可查看相应权限新闻。管理...

    一个多层架构多种数据库结合NHibernate和Ext.Net实现用户增删除改查的小例子

    本来想像petshop一样做多个DAL来执行不同的代码的,但使用NHibernate之后发现他就可以通过不同的配置来实现连接不同的数据库,原系统中的HSRK.DALAccess,HSRK.DALOracle也没有删除。但没有实现代码。 Access库就...

    Spring.net Nhibernate 快速入门例子

    我写的Spring.net+Nhibernate测试例子,vs2005 下编译通过,相信对初学者有帮助,数据库:sqlserver2000

    一个多层架构多种数据库结合NHibernate和Ext.Net及Newtonsoft.Json实现用户增删除改查的小例子

    本来想像petshop一样做多个DAL来执行不同的代码的,但使用NHibernate之后发现他就可以通过不同的配置来实现连接不同的数据库,原系统中的HSRK.DALAccess,HSRK.DALOracle也没有删除。但没有实现代码。 Access库就...

    SSH例子

    功能:使用dwr完成在客户端无刷新的分页排序等 &lt;br&gt;工具:MyEclipse 6.0,数据库SQLSERVER 2000 &lt;br&gt;数据在SQL文件夹下,Jobs是pubs数据库自带的 &lt;br&gt;主要的三个页面,emp是详细的,另两个是简单的复制修改,...

    自己写的ssh例子 网上购物的 带购物车的

    自己用ssh框架写的例子 数据库是sqlserver 2005

    使用Swing书写一个简单的Java代码生成器

    运行环境:Windows XP、JDK 6.0、SQL Server 2000、Oracle 9i、Eclipse 3.3 使用步骤: 1. 下载解压之后使用IDE导入工程 2. 检查一下工程是否导入了lib目录下的数据库驱动,如果导入,那么需要导入这些包 3. 运行...

Global site tag (gtag.js) - Google Analytics