delete_stm.setString(i+1,param[i]);
delete_stm.executeUpdate();
delete_stm.close();
mit();
}
catch(Exceptione)
{
System.out.println(e);
conn.rollback();
}
}
}
Java/JSP中使用JDBC连接SQLServer2005
准备工作
首先,要到微软网站下载MicrosoftSQLServer2005JDBCDriver2.0,下载完成后,解压,把目录里面的sqljdbc_2.0复制到%ProgramFiles%(具体看你的系统盘在哪个盘,如在C盘,则放在C:
\ProgramFiles,本文也以C:
\ProgramFiles为例)
设置ClassPath
JDBC驱动程序并未包含在JavaSDK中。
因此,如果要使用该驱动程序,必须将classpath设置为包含sqljdbc4.jar文件。
如果classpath缺少sqljdbc4.jar项,应用程序将引发“找不到类”的常见异常。
(注,因为本文章主要是针对sql2005,所以这里的驱动程序应该是sqljdbc4.jar,而不是网上说的sqljdbc.jar)
sqljdbc4.jar文件的安装位置如下:
<安装目录>\sqljdbc_<版本>\<语言>\sqljdbc4.jar
即:
C:
\ProgramFiles\sqljdbc_2.0\chs\sqljdbc4.jar
接下来设置ClassPath
右键“计算机”属性->高级系统设置->“高级”选项卡->环境变量->在用户变量里新建一个变量名为ClassPath,变量值为%ProgramFiles%\sqljdbc_2.0\chs\sqljdbc4.jar的用户变量->确定完成。
(注意:
在Window系统中,如果目录名长于8.3或文件夹名中包含空格,将导致classpath出现问题。
如果怀疑存在这类问题,应暂时将sqljdbc.jar文件移动到名称简单的目录中,例如C:
\Temp,更改classpath,然后测试这样是否解决了问题。
)
设置SQLServer服务器
我使用的是SQLServer2005标准版SP2,这些都默认即可,一般不用配置。
如果需要配置端口请看下面。
1、“开始”→“程序”→“MicrosoftSQLServer2005”→“配置工具”→“SQLServer配置管理器”→“SQLServer2005网络配置”→“MSSQLSERVER的协议”
2、如果“TCP/IP”没有启用,右键单击选择“启动”。
3、双击“TCP/IP”进入属性设置,在“IP地址”里,可以配置“IPAll”中的“TCP端口”,默认为1433。
4、重新启动SQLServer或者重启计算机。
在Eclipse中测试
1、打开Eclipse,“文件”→“新建”→“项目”→“Java项目”,项目名为Test
2、在Eclipse中,选择“窗口”→“首选项...”→“Java”→“已安装的JRE”,选择已安装的JRE,点击“编辑”→“添加外部”,选择%ProgramFiles%\sqljdbc_2.0\chs\sqljdbc4.jar
3、在Test项目的“JRE系统库”中可以看见sqljdbc.jar,如果没有可以右键单击项目Test→“构建路径”→“配置构建路径...”→“Java构建路径”→“库”→“添加外部JAR...”,选择%ProgramFiles%\sqljdbc_2.0\chs\sqljdbc4.jar
4、编写Java代码,如下:
1importjava.sql.*;
2
3 publicclassTest{
4publicstaticvoidmain(String[]srg){
5StringdriverName="com.microsoft.sqlserver.jdbc.SQLServerDriver";//加载JDBC驱动
6 StringdbURL="jdbc:
sqlserver:
//localhost:
1433;DatabaseName=test";//连接服务器和数据库test
7StringuserName="sa";//默认用户名
8StringuserPwd="123456";//密码
9ConnectiondbConn;
10try{
11Class.forName(driverName);
12dbConn=DriverManager.getConnection(dbURL,userName,userPwd);
13System.out.println("ConnectionSuccessful!
");//如果连接成功控制台输出ConnectionSuccessful!
14}catch(Exceptione){
15e.printStackTrace();
16}
17}
18}
java连接sqlserver
2009-12-2722:
42:
58| 分类:
Java浅谈| 标签:
|字号大中小 订阅
用Java连接SQLServer2000数据库有多种方法,下面介绍其中最常用的两种(通过JDBC驱动连接数据库)。
1.通过Microsoft的JDBC驱动连接。
此JDBC驱动共有三个文件,分别是mssqlserver.jar、msutil.jar和msbase.jar,可以到微软的网站去下载(JDBC2.0。
驱动程序名称:
com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的classforname)
数据库连接URL:
jdbc:
microsoft:
sqlserver:
//localhost:
1433;DatabaseName=dbname(即下面的url)
2.通过JTDSJDBCDriver连接SQLServer数据库,此驱动的文件名为jtds-1.2.jar,下载路径为(SQLServer(6.5,7.0,2000和2005)和Sybase,并且实现了JDBC3.0,是免费的。
驱动程序名称:
net.sourceforge.jtds.jdbc.Driver(即下面的classforname)
数据库连接URL:
jdbc:
jtds:
sqlserver:
//localhost:
1433/dbname(即下面的url)
JDBC连接SQLServer数据库的Bean代码网上大把的有,下面摘录其中的一部分:
(请将localhost和1433改成你实际应用中的SQLServer服务器地址和端口号,dbname改成你实际的数据库名)
importjava.sql.*;
publicclassDatabaseConn{
privateConnectionconn;
privateStatementstmt;
privateStringurl="jdbc:
microsoft:
sqlserver:
//localhost:
1433;DatabaseName=dbname";
privateStringclassforname="com.microsoft.jdbc.sqlserver.SQLServerDriver";
privateStringuid="sa";
privateStringpwd="password";
publicDatabaseConn(){}
publicConnectiongetConnection()
{
try
{
Class.forName(classforname);
if(conn==null||conn.isClosed())
conn=DriverManager.getConnection(url,uid,pwd);
}
catch(ClassNotFoundExceptionex)
catch(SQLExceptionex)
returnconn;
}
}
当然,在做上述工作之前,你得先检查自己的SQLServer设置是否有问题,步骤如下:
首先打开“命令行窗口”,也就是MS-Dos窗口,输入
telnetlocalhost1433 (当然,用SQLServer所在的服务器地址替代localhost,端口改为SQLServer的实际端口,默认是1433)
如果成功了,表明你的SQLServer是可以连上的,如果没成功(一般是对于Win2003或者WinXPSP2),请进入控制面板,打开“管理工具”中的“服务”,启动“SQLSERVERAGENT”服务(当然,你也可以打上SQLServer的SP3补丁包),再继续上面的操作,应该会成功的。
其次,检查你的用户名和密码是否能登陆SQLServer服务器,当然,最直接的办法就是打开SQLServer的“查询分析器”,输入用户名和密码,点击确定
如果成功了,表明你的SQLServer登陆设置没问题,如果失败了,请打开SQLServer的“企业管理器”,在你注册的SQLServer服务器上(也就是左边的“SQLServer组”下面的那东东)也就是点击右键,选择“属性”,在“SQLServer(属性)配置”对话框中选择“安全性”,将身份验证设为“SQLServer和Windows(S)”,再用查询分析器测试一次,如果还连接不上,就去检查你的用户名和密码是否有误。
重复测试,直至成功。
oralceUitlPool.java
packagecom.oneworld.util;
importjava.sql.Connection;
importjava.sql.DriverManager;
importjavax.naming.InitialContext;
importjavax.sql.DataSource;
/**
*@authormmode
*
*/
publicclassoralceUitlPool{
staticConnectionconn=null;
publicstaticConnectiongetConnection(){
InitialContextinitctx;
try{
initctx=newInitialContext();
DataSourceds=(DataSource)initctx.lookup("java:
comp/env/jdbc/vodone");
conn=ds.getConnection();
}catch(Exceptione){
e.printStackTrace();
}
returnconn;
}
publicstaticConnectionConnectToDB()
{
try
{
StringoURL="192.168.5.92";
StringoPort="1521";
StringoService="smsdb";
StringoUser="gtsms";
StringoPassword="gtsms";
StringsdName="oracle.jdbc.driver.OracleDriver";
Class.forName(sdName);
StringconnStr="jdbc:
oracle:
thin:
@"+oURL+":
"+oPort+":
"+oService;
conn=DriverManager.getConnection(connStr,oUser,oPassword);
}
catch(Exceptione)
{
System.out.println(e);
}
returnconn;
}
publicstaticvoidmain(String[]args)
{
oralceUitlPooloup=neworalceUitlPool();
oup.getConnection();
}
}
DBUtil.java
packagecom.oneworld.util;
importjava.sql.Connection;
importjava.sql.ResultSet;
importjava.sql.SQLException;
importjava.sql.Statement;
/******
*使用连接池连接数据库,提供对数据库操作的各个接口
*@authormmode
*
*/
publicclassDBUtil{
privateConnectionconn=null;
privateStatementstmt=null;
privateResultSetrs=null;
publicDBUtil(){
//conn=oralceUitlPool.getConnection();
conn=oralceUitlPool.ConnectToDB();
try{
stmt=conn.createStatement();
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
}
/*************
*数据库操作----增加
*@paramsql:
将要执行的SQL语句
*@return:
执行成功了,返回true,执行不成功,返回false
*/
publicbooleanExeInser(Stringsql){
booleanflag=true;
try{
stmt.execute(sql);
flag=true;
}ca