Java连接SQLServer.docx

上传人:b****8 文档编号:10945221 上传时间:2023-02-23 格式:DOCX 页数:14 大小:20.16KB
下载 相关 举报
Java连接SQLServer.docx_第1页
第1页 / 共14页
Java连接SQLServer.docx_第2页
第2页 / 共14页
Java连接SQLServer.docx_第3页
第3页 / 共14页
Java连接SQLServer.docx_第4页
第4页 / 共14页
Java连接SQLServer.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

Java连接SQLServer.docx

《Java连接SQLServer.docx》由会员分享,可在线阅读,更多相关《Java连接SQLServer.docx(14页珍藏版)》请在冰豆网上搜索。

Java连接SQLServer.docx

Java连接SQLServer

  我们在做jsp开发的时候,经常需要对数据库进行查询及增删改,而这些操作使用的又是非常频繁,因此,我写了一个javabean,来实现与数据库的连接以及对数据库的增删改。

现在拿出来与大家共享,希望大家尊重作者的劳动,使用时保留作者信息以及版本信息等等,谢谢!

QueryBean.java:

pacakageoperate_db;

/**

 *Title:

        selectinsertupdateanddelete

 *Description:

  selectinsertupdateanddelete

 *Copyright:

   Copyright(c)2001

 *@author Lci21

 *@version1.0

 */

importjava.sql.*;

publicclassQueryBean

{   

   publicStringquery_statement; /*定义sql语句*/

   publicStringparam[];         /*查询条件,或者是新的记录*/

   publicResultSetresult=null;   

   publicConnectionconn;

   

   publicvoidsetParam(String[]param)

   {

       this.param=param;

   }

   publicvoidsetQuerystatement(Stringquery_statement)

   {

       this.query_statement=query_statement;

   }

   publicvoidsetConnection(StringdriverName,StringjdbcURL,Stringusername,Stringpasswd)throwsException

   {

       Connectionconn1;

       Class.forName(driverName);

       conn1=DriverManager.getConnection(jdbcURL,username,passwd);

       conn1.setAutoCommit(false);

       this.conn=conn1;

   }

   /*获取查询结果*/

   publicResultSetgetResult()  

   {

       try

       {

           PreparedStatementselect_stm=conn.prepareStatement(query_statement,java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);

           if(param!

=null)

                   for(inti=0;i

                       select_stm.setString(i+1,param[i]);

           result=select_stm.executeQuery();                                       

       }catch(Exceptione){System.out.println(e);}

       returnresult;

   }

    

 /*对数据库进行增加记录操作*/   

   publicvoidinsertRecord()throwsSQLException,java.io.UnsupportedEncodingException

   {

       try

       {

           PreparedStatementinsert_stm=conn.prepareStatement(query_statement);

           if(param!

=null)

               for(inti=0;i

                   insert_stm.setString(i+1,param[i]);

           insert_stm.executeUpdate();

           insert_stm.close();

           mit();

       }

       catch(Exceptione)

       {

           System.out.println(e);

           conn.rollback();

       }       

   }

         

 /*对数据记录进行更改操作*/      

       publicvoidupdateRecord()throwsSQLException,java.io.UnsupportedEncodingException

       {

           try

           {

               PreparedStatementupdate_stm=conn.prepareStatement(query_statement);

               if(param!

=null)

                   for(inti=0;i

                       update_stm.setString(i+1,param[i]);

               update_stm.executeUpdate();

               update_stm.close();

               mit();

           }

           catch(Exceptione)

           {

               System.out.println(e);

               conn.rollback();

           }

       }

  /*删除数据记录*/                          

       publicvoiddeleteRecord()throwsSQLException,java.io.UnsupportedEncodingException

       {

           try

           {

               PreparedStatementdelete_stm=conn.prepareStatement(query_statement);

               if(param!

=null)

                   for(inti=0;i

                       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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 经济学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1