Hibernate连接SQLServer2000数据库(例子)

2024-02-21 05:18

本文主要是介绍Hibernate连接SQLServer2000数据库(例子),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

先从例子开始(使用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 - 狂风

 

这篇关于Hibernate连接SQLServer2000数据库(例子)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/730670

相关文章

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma