JAVA连接SQL SERVER2000数据库的方法

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
private Connection conn; private Statement stmt; private String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname"; private String classforname = "com.microsoft.jdbc.sqlserver.SQLServerDriver"; private String uid = "sa"; private String pwd = "password";
其次,检查你的用户名和密码是否能登陆 SQL Server 服务器,当然,最直接的办法就是打开 SQL Server 的“查询分析器”,输入用户名和密码,点击确定
如果成功了,表明你的 SQL Server 登陆设置没问题,如果失败了,请打开 SQL Server 的“企业管理器”, 在你注册的 SQL Server 服务器上(也就是左边的“SQL Server 组”下面的那东东)也就是点击右键,选 择“属性”,在“SQL Server (属性) 配置”对话框中选择“安全性”,将身份验证设为“SQL Server 和 Windows(S)”,再用查询分析器测试一次,如果还连接不上,就去检查你的用户名和密码是否有误。重复 测试,直至成功。
public DatabaseConn(){}
/** * <p>通过 Microsoft JDBC 驱动获得数据库连接</p> * @return Connection * @exception ClassNotFoundException, SQLException */
public Connection getConnection() { try {
如果成功了,表明你的 SQL Server 是可以连上的,如果没成功(一般是对于 Win2003 或者 WinXP SP2), 请进入控制面板,打开“管理工具”中的“服务”,启动“SQLSERVERAGENT”服务(当然,你也可以打上 SQL Server 的 SP3 补丁包),再继续上面的操作,应该会成功的。
如果在 JSP 中应用连接,当然,除了直接用 JDBC 外,大伙最热衷于来自百度文库
的莫过于连接池(Pool)了,下面着重介绍一下连接池的几种用法。
为了方便,先设定 JSP 容器为 Tomcat,因为大家用得比较多
1. 全局配置(Tomcat 里的任何 Web 应用都能使用该配置的连接池):在 server.xml 里面配 置连接池,server.xml 文件位于 $TOMCAT_HOME$/conf/目录下,打开它,找到 </GlobalNamingResources>,并在这一行的前面插入如下代码:
找到</Context>,并在这一行的前面插入如下代码: <ResourceLink global="jdbc/poolName" name="jdbc/poolName" type="javax.sql.DataSource"/>
2. 局部配置:在$TOMCAT_HOME$/conf/Catalina/localhost/目录下新建一个 xml 文件,该 xml 文 件要与你发布的 Web 应用目录名称相同,假如为 webappname.xml,加入以下内容(配置 Tomcat 的 外部虚拟目录也是在这里搞掂的,哈!)
JDBC 连接 SQL Server 数据库的 Bean 代码网上大把的有,下面摘录其中的一部分:(请将 localhost 和 1433 改成你实际应用中的 SQL Server 服务器地址和端口号,dbname 改成你实际的数据库名)
import java.sql.*; public class DatabaseConn {
<Resource name="jdbc/poolName" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="password" driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver" url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/>
<Context path="/webappname" docBase="d:/webappname" debug="0" reloadable="true" crossContext="true"> <Resource
name="jdbc/poolName" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="password" driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver" url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/> <ResourceLink global="jdbc/poolName" name="jdbc/poolName" type="javax.sql.DataSource"/> </Context>
Class.forName(classforname);
if (conn == null || conn.isClosed()) conn = DriverManager.getConnection( url, uid, pwd); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return conn; }
}
在使用上述代码之前,必须保证 JDBC 驱动的相关 JAR 文件(Microsoft 为 mssqlserver.jar、msutil.jar 和 msbase.jar,JTDS 为 jtds-1.2.jar)已正确配置,
可以将相关 JAR 文件拷贝到$TOMCAT_HOME$/common/lib/目录下,也可以拷贝到 $WEB_ROOT$/WEB-INF/lib/目录下
还可以用注入方式来调用连接池,即在 Hibernate 的配置文件 hibernate.cfg.xml 中调用,在 JSP 容器中配置好连接池以后,再在 Hibernate 的配置文件中调用系统的连接池设置,关键代 码摘录如下:
<session-factory> <!-<property name="jndi.class"></property> <property name="jndi.url"></property> --> <property name="connection.datasource">java:comp/env/jdbc/poolName</property> <property name="show_sql">false</property> <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>
用 Java 连接 SQL Server2000 数据库有多种方法,下面介绍其中最
常用的两种(通过 JDBC 驱动连接数据库)。
1. 通过 Microsoft 的 JDBC 驱动连接。此 JDBC 驱动共有三个文件,分别是 mssqlserver.jar、msutil.jar 和 msbase.jar,可以到微软的网站去下载 (http://www.microsoft.com/downloads/details.aspx?FamilyId=07287B11-0502-461A-B13 8-2AA54BFDC03A&displaylang=en),如果你下载的是 setup.exe,还需要安装它,安装后会生成上 面的三个 jar 文件。此 JDBC 驱动实现了 JDBC 2.0。 驱动程序名称:com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的 classforname) 数据库连接 URL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname(即下面 的 url)
public DataPool(){}
/** * <p>通过 Tomcat 连接池取得数据库连接</p> * @param no * @return Connection 数据库连接 * @exception NamingException,SQLException,Exception */
public Connection getConnect() { Connection conn = null; try {
注意:name 为连接池的全局 JNDI 全称,username 为 password 为数据库的连接用户名和 密码,driverClassName 是数据库驱动名称,url 是数据库连接字符串。请按照你的实际配置 进行修改。 配置到这里还没有算完成,下面要在 context.xml 里面设置全局访问的名称,设置如下:
2. 通过 JTDS JDBC Driver 连接 SQL Server 数据库,此驱动的文件名为 jtds-1.2.jar,下载路径为 (http://sourceforge.net/project/showfiles.php?group_id=33291),此驱动支持 Microsoft SQL Server (6.5, 7.0, 2000 和 2005) 和 Sybase,并且实现了 JDBC3.0,是免费的。 驱动程序名称:net.sourceforge.jtds.jdbc.Driver(即下面的 classforname) 数据库连接 URL:jdbc:jtds:sqlserver://localhost:1433/dbname(即下面的 url)
Context intitCtx = new InitialContext(); Context envCtx = (Context)intitCtx.lookup("java:comp/env"); DataSource ds = (DataSource)envCtx.lookup("jdbc/poolName"); conn = ds.getConnection(); } catch(NamingException nex) { Debug.log(this,"getConnect()","No correct environment!"); } catch(SQLException sqlex) { Debug.log(this,"getConnect()","Can't get connection!"); } return conn; }
}
当然,在做上述工作之前,你得先检查自己的 SQL Server 设置是否有问题,步骤如下:
首先打开“命令行窗口”,也就是 MS-Dos 窗口,输入 telnet localhost 1433 (当然,用 SQL Server 所在的服务器地址替代 localhost,端口改为 SQL Server 的实际端口,默认是 1433)
对于前面两种方法,调用连接池代码如下:(其中 com.yeno.util.Debug 的 Debug.log()方 法主要用于打印调试信息,可以用 System.out.println()代替)
import java.sql.*; import javax.sql.DataSource; import javax.naming.*; import com.yeno.util.Debug; /** * <p>数据库操作管理类,只实现数据库的连接,关闭和事务处理</p> * @Aurhor Yeno.hhr * Create Date 2005-12-9 */ public class DataPool {
相关文档
最新文档