如何连接SQL Server数据库(Java)用Java连接SQL Server2000数据库有多种方法,下面介绍其中最常用的两种(通过JDBC 驱动连接数据库)。
1. 通过Microsoft的JDBC驱动连接。
此JDBC驱动共有三个文件,分别是mssqlserver.jar、msutil.jar和msbase.jar,可以到微软的网站去下载(/downloa ... &displaylang=en),如果你下载的是setup.exe,还需要安装它,安装后会生成上面的三个jar 文件。
此JDBC驱动实现了JDBC2.0。
驱动程序名称:com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的classforname)数据库连接URL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname(即下面的url)2. 通过JTDS JDBC Driver连接SQL Server数据库,此驱动的文件名为jtds-1.2.jar,下载路径为(/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)JDBC连接SQL Server数据库的Bean代码网上大把的有,下面摘录其中的一部分:(请将localhost和1433改成你实际应用中的SQL Server服务器地址和端口号,dbname改成你实际的数据库名)1.import java.sql.*;2.public class DatabaseConn {3.4.private Connection conn;5.private Statement stmt;6.private String url ="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname";7.private String classforname ="com.microsoft.jdbc.sqlserver.SQLServerDriver";8.private String uid = "sa";9.private String pwd = "password";10.11.public DatabaseConn(){}12.13./**14. * <p>通过Microsoft JDBC驱动获得数据库连接</p>15. * @return Connection16. * @exception ClassNotFoundException, SQLException17. */18.public Connection getConnection()19.{20. try21. {22. Class.forName(classforname);23. if (conn == null || conn.isClosed())24. conn = DriverManager.getConnection( url, uid, pwd);25. }26. catch (ClassNotFoundException ex)27. {28. ex.printStackTrace();29. }30. catch (SQLException ex)31. {32. ex.printStackTrace();33. }34. return conn;35.}36.37.}复制代码当然,在做上述工作之前,你得先检查自己的SQL Server设置是否有问题,步骤如下:首先打开“命令行窗口”,也就是MS-Dos窗口,输入telnet localhost 1433 (当然,用SQL Server所在的服务器地址替代localhost,端口改为SQLServer的实际端口,默认是1433)如果成功了,表明你的SQL Server是可以连上的,如果没成功(一般是对于Win2003或者WinXP SP2),请进入控制面板,打开“管理工具”中的“服务”,启动“SQLSERVERAGENT”服务(当然,你也可以打上SQL Server的SP3补丁包),再继续上面的操作,应该会成功的。
其次,检查你的用户名和密码是否能登陆SQL Server服务器,当然,最直接的办法就是打开SQL Server的“查询分析器”,输入用户名和密码,点击确定如果成功了,表明你的SQL Server登陆设置没问题,如果失败了,请打开SQL Server的“企业管理器”,在你注册的SQL Server服务器上(也就是左边的“SQL Server组”下面的那东东)也就是点击右键,选择“属性”,在“S QL Server (属性)配置”对话框中选择“安全性”,将身份验证设为“SQL Server和Windows(S)”,再用查询分析器测试一次,如果还连接不上,就去检查你的用户名和密码是否有误。
重复测试,直至成功。
如果在JSP中应用连接,当然,除了直接用JDBC外,大伙最热衷于的莫过于连接池(Pool)了,下面着重介绍一下连接池的几种用法。
为了方便,先设定JSP容器为Tomcat,因为大家用得比较多1. 全局配置(Tomcat里的任何Web应用都能使用该配置的连接池):在server.xml里面配置连接池,server.xml文件位于$TOMCAT_HOME$/conf/目录下,打开它,找到</GlobalNamingResources>,并在这一行的前面插入如下代码:1.<Resource2. name="jdbc/poolName"3. auth="Container"4. type="javax.sql.DataSource"5. maxActive="100"6. maxIdle="30"7. maxWait="10000"8. username="sa"9. password="password"10. driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"11. url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/>复制代码注意:name为连接池的全局JNDI全称,username为password为数据库的连接用户名和密码,driverClassName是数据库驱动名称,url是数据库连接字符串。
请按照你的实际配置进行修改。
配置到这里还没有算完成,下面要在context.xml里面设置全局访问的名称,设置如下:找到</Context>,并在这一行的前面插入如下代码:1.<ResourceLink global="jdbc/poolName" name="jdbc/poolName"type="javax.sql.DataSource"/>复制代码2. 局部配置:在$TOMCA T_HOME$/conf/Catalina/localhost/目录下新建一个xml文件,该xml 文件要与你发布的Web 应用目录名称相同,假如为webappname.xml,加入以下内容(配置Tomcat的外部虚拟目录也是在这里搞定的,哈!)1.<Context path="/webappname" docBase="d:/webappname" debug="0"reloadable="true" crossContext="true">2.<Resource3. name="jdbc/poolName"4. auth="Container"5. type="javax.sql.DataSource"6. maxActive="100"7. maxIdle="30"8. maxWait="10000"9. username="sa"10. password="password"11. driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"12. url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/>13.<ResourceLink global="jdbc/poolName" name="jdbc/poolName"type="javax.sql.DataSource"/>14.</Context>复制代码对于前面两种方法,调用连接池代码如下:(其中com.yeno.util.Debug的Debug.log()方法主要用于打印调试信息,可以用System.out.println()代替) (注意, 这个类只能在Tomcat 里运行)1.import java.sql.*;2.import javax.sql.DataSource;3.import javax.naming.*;4.import com.yeno.util.Debug;5./**6.* <p>数据库操作管理类,只实现数据库的连接,关闭和事务处理</p>7.*8.*/9.public class DataPool {10.11.public DataPool(){}12./**13. * <p>通过Tomcat连接池取得数据库连接</p>14. * @param no15. * @return Connection 数据库连接16. * @exception NamingException,SQLException,Exception17. */18.public Connection getConnect()19.{20. Connection conn = null;21. try22. {23. Context intitCtx = new InitialContext();24. Context envCtx = (Context)intitCtx.lookup("java:comp/env");25. DataSource ds = (DataSource)envCtx.lookup("jdbc/poolName");26. conn = ds.getConnection();27. }28. catch(NamingException nex)29. {30. Debug.log(this,"getConnect()","No correct environment!");31. }32. catch(SQLException sqlex)33. {34. Debug.log(this,"getConnect()","Can't get connection!");35. }36. return conn;37.}38.39.}复制代码在使用上述代码之前,必须保证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的配置文件中调用系统的连接池设置,关键代码摘录如下:1.<session-factory>2.<!--3.<property name="jndi.class"></property>4.<property name="jndi.url"></property>5.-->6.<propertyname="connection.datasource">java:comp/env/jdbc/poolName</property>7.<property name="show_sql">false</property>8.<propertyname="dialect">org.hibernate.dialect.SQLServerDialect</property>9.</session-factory>复制代码。