前言

  Lz主要目的是在Spring中配置SQL server 2000数据库,但实现目的的过程中参差着许多SQL server 2000的知识,也包罗在本文记载下来!(Lz为什么要去搞sql server2000而不去搞2005或2008的,Lz所处的环境需求,这点是小问题,别在意)

Spring里面主要的配置

  1. <property name="driverClass">
  2. <value>net.sourceforge.jtds.jdbc.Driver</value>
  3. </property>
  4. <property name="jdbcUrl">
  5. <value>jdbc:jtds:sqlserver://localhost;DatabaseName=snack</value>
  6. </property>
  7. <property name="user">
  8. <value>sa</value>
  9. </property>
  1. <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>

  主要导入的jar包有jtds-1.2.5.jar,上面的localhost也可以写成localhost:1433,两者都可以运行,在这配置前,记得得先测试下你的sql server端口弄好了没!

在spring中配置sqlserver的数据源时出现:com.microsoft.jdbc.base.BaseDatabaseMetaData.supportsGetGeneratedKeys()Z

  网上大多是以下面的方式来配置的,导入的包有msbase.jar、mssqlserver.jar、msutil.jar,但我配了很久都没成功,上网查了下原因,有人说是microsoft存在的bug,说是在java代码调原驱动是没有问题的,但在hibernate就不是了。所以就改成了我现在的配置,行得通

  1. <property name="connection.driver_class">com.microsoft.jdbc.sqlserver.SQLServerDriver</property>
  2. <property name="connection.url">jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=hibernate</property>

在这种配置时,我是出现了以下错误,一开始我查了好久sessionFactory的bean里面,但最后却是改了bean为dataSource的上面这两句来解决的

  1. org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in file [E:\Workspace\131112_snack\snackClient\src\applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.AbstractMethodError: com.microsoft.jdbc.base.BaseDatabaseMetaData.supportsGetGeneratedKeys()Z

SQL Server 不能创建数据库,发生错误:1807 未能获得数据库 'test' 上的排它锁。请稍后重试操作。

  在sql 查询分析器的test数据库运行下面的语句

  1. declare @sql varchar(100)
  2. while 1=1
  3. begin
  4. select top 1 @sql = 'kill '+cast(spid as varchar(3))
  5. from master..sysprocesses
  6. where spid > 50 and spid <> @@spid
  7. if @@rowcount = 0
  8. break
  9. exec(@sql)
  10. end

以前进行的程序安装创建了挂起的文件操作。运行安装程序之前,必须重新启动计算机

  这个问题我遇到了两次,一次是在安装SQL server 2000时,另一次是在安装SQL2000-KB884525-SP4-x86-CHS.EXE的时候,虽然情况不同,但解决方法是一样的,就是重新启动计算机都是没用的,可以用下面的方法解决:regedit打开注册表,在HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/Session Manager中找到PendingFileRenameOperations文件,并删除它。

与SQL server 2000的1433相关知识

  一开始我搞了好久没连接成功,无意间发现我电脑服务上没有运行SQL server 2000的1433的服务端口,以此学习有些相关的知识

  1. win7下出现telnet不是内部或外部的命令
    开始-->控制面版-->打开或关闭windows功能,勾选Telnet客户端,确定
  2. SQL server 的客户端网络实用工具或者服务端网络实用工具,选择TCP/IP后单击属性,可以看到SQL server的端口
  3. dos里面使用telnet localhost 1433可以连接电脑的1433端口
  4. 在任务管理器的服务里可以看到运行软件的PID,可以以此PID在dos窗口里面使用netstat -ano来查看所对应的端口号如下图

  5. 如果此时找不到1433的端口,可以试着下载个SQL2000-KB884525-SP4-x86-CHS.EXE更新试试看,双击打开只能算是解压,不算是安装,真正的安装是到你解压的目录后进入x86\setup\setupsql.exe进行安装,在此步骤遇到的问题上面文中也有解决了一些

注意项

  1. 在Spring配置这句<prop key="hibernate.hbm2ddl.auto">update</prop>时,会自动生成表,但不会自动生成数据库,在没有相应的数据库时运行会出错
  2. sql server不能创建表名为user,会报org.springframework.jdbc.BadSqlGrammarException: Hibernate operation: could not insert: [snack.bean.user]; bad SQL grammar [insert into user (userName, userPwd, userTel, jsId) values (?, ?, ?, ?)]; nested exception is java.sql.SQLException: 在关键字 'user' 附近有语法错误。
  3. dos命令net start MSSQLSERVER启动MSSQLSERVER服务,net stop MSSQLSERVER关闭MSSQLSERVER服务

在Spring中配置SQL server 2000的更多相关文章

  1. 配置sql server 2000以允许远程访问 及 连接中的四个最常见错误

    地址:http://www.cnblogs.com/JoshuaDreaming/archive/2010/12/01/1893242.html 配置sql server 2000以允许远程访问适合故 ...

  2. 配置sql server 2000以允许远程访问

    配置sql server 2000以允许远程访问适合故障:1. 用sql企业管理器能访问sql server 2000(因为它是采用命名管道(named pipes)方式进行方式),但用ado.net ...

  3. 在 Azure CentOS VM 中配置 SQL Server 2019 AG - (上)

    前文 假定您对Azure和SQL Server HA具有基础知识 假定您对Azure Cli具有基础知识 目标是在Azure Linux VM上创建一个具有三个副本的可用性组,并实现侦听器和Fenci ...

  4. 如何修改SQL Server 2000的数据库逻辑与物理名称

    在项目中使用SQL Server 2000创建了一个数据库,发现名称与另一个数据库太相似,于是决定更改名称,包括: 在企业管理器中看到的数据库名,也是实际应用程序中连接用的数据库名称: 在磁盘上看的物 ...

  5. SQL Server 2000的安全配置

    SQL Server 2000的安全配置 数据库是电子商务.金融连同ERP系统的基础,通常都保存着重要的商业伙伴和客户信息.大多数企业.组织连同政府 部门的电子数据都保存在各种数据库中,他们用这些数据 ...

  6. SQL Server 2000详细安装过程及配置

    说明:这篇文章是几年前我发布在网易博客当中的原创文章,但由于网易博客现在要停止运营了,所以我就把这篇文章搬了过来,虽然现如今SQL Server 2000软件早已经过时了,但仍然有一部分人在使用它,尤 ...

  7. sql server 2000安装程序配置服务器失败

    第一种方法 今天安装SQL Server 2000遇到了个很BT的问题,提示出下: 安装程序配置服务器失败.参考服务器错误日志和C:\Windows\sqlstp.log了解更多信息. 以前进安装目录 ...

  8. SQL Server 2000中的完整备份、差异备份操作

    在SQL Server 2000中,假定我们拥有一个数据库为:Test, 现在需要它每天19:00自动进行一次备份,并且以后一旦发生数据库错误,我们都可以通过备份文件将数据库恢复到任何一个备份过的时刻 ...

  9. SQL Server 2000中的并行处理和执行计划中的位图运算符

    SQL Server 2000中的并行处理和执行计划中的位图运算符 摘抄自:SQLServer 2000并行处理和位图简介 刘志斌 并行查询介绍Degree of Parallelism(并行度) 一 ...

随机推荐

  1. java Comparable 和 Comparator接口区别

    Comparable 简介 Comparable 是排序接口. 若一个类实现了Comparable接口,就意味着“该类支持排序”.  即然实现Comparable接口的类支持排序,假设现在存在“实现C ...

  2. Spring+SpringMVC+mybatis整合以及注解的使用(三)

    1.包结构:

  3. Android常用逆向工具+单机游戏破解

    android开发环境搭建 我理解的学习路线是首先要掌握和了解常见的工具.搭建环境.然后就是缓慢的积累特征,通过长期的练习使自己进步,通过android逆向课程的学习.常用的工具如下: android ...

  4. Linux动态频率调节系统CPUFreq之一:概述【转】-- 非常好的博客

    转自:http://blog.csdn.net/droidphone/article/details/9346981     目录(?)[-] sysfs接口 软件架构 cpufreq_policy ...

  5. openstack新版本ocata的接口改动

    新增placement API,部分替代了原先的nova api的部分功能接口 可在此页面查看API详情及示例:https://specs.openstack.org/openstack/nova-s ...

  6. nodejs前端开发环境安装

    1.       nodejs安装 要求:node版本6.2.0及以上,npm版本3.8.9及以上 Nodejs安装包地址: 2.    在rTools上下载并安装git 3.    在rTools上 ...

  7. python 语言特性

    动态强类型: 动态类型语言:在运行期进行类型检查的语言,也就是在编写代码的时候可以不指定变量的数据类型,比如Python和Ruby 静态类型语言:它的数据类型是在编译期进行检查的,也就是说变量在使用前 ...

  8. 前端web服务器数据同步方案

    概述: 网站采用了web和mysql数据库分离的架构,前端有web1.web2.web3需要对他们进行上传文件同步 方案: 在web2的windows服务器上安装GoodSync软件,利用其双向同步特 ...

  9. androidpn 推送系统

    (文中部分内容来自网络,如无意中侵犯了版权,请告之!) XMPP协议: XMPP : The Extensible Messaging andPresence Protocol. 中文全称:可扩展通讯 ...

  10. Java中的BlockingQueue队列

    BlockingQueue位于JDK5新增的concurrent包中,它很好地解决了多线程中,如何高效安全地“传输”数据的问题.通过这些高效并且线程安全的队列类,为我们快速搭建高质量的多线程程序带来极 ...