学JSP的同学都要知道怎么连数据库,网上的示例各有各的做法,弄得都不知道用谁的好。其实方法千变万化,本质上就两种:Jdbc-Odbc桥和Jdbc直连。

下面先以MySQL为例说说这两种方式各是怎么连的?

方式一:Jdbc-Odbc桥

它所要用到的有JSP自带的驱动 sun.jdbc.odbc.JdbcOdbcDriver 和 Windows系统中的 ODBC数据源。这两种好在都不用下载,可以直接使用。原理是网页向Jdbc驱动请求数据,Jdbc再向Odbc请求,最后Odbc向数据库请求。Odbc我这里就不多说了,先用它建立一个MySQl的数据源,最好是系统数据源,过程中可能需要到 MySQL for ODBC 的驱动,如果没有则先安装,测试成功后留下待用。

接下来就编写一个JSP网页测试一下,代码如下:

 1 <%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql.*" errorPage="" %>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <title>连接MySQL</title>
6 </head>
7 <body>
8 <%
9 //以下是关键部分
10 Connection con=null;
11 String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
12 String DBname="jdbc:odbc:你的数据源名";
13 String DBuser="root";
14 String DBcode="123";
15 //以上是关键部分
16 try
17 {
18 Class.forName(DriverName);
19 }
20 catch(Exception e)
21 {
22 out.print(e.toString());
23 }
24 try
25 {
26 con=DriverManager.getConnection(DBname,DBuser,DBcode);
27 }
28 catch(SQLException e)
29 {
30 out.print(e.toString());
31 }
32 %>
33 <p><b>JDBC连接ODBC数据库测试结果</b></p>
34 <%
35 if(con!=null)
36 {
37 DatabaseMetaData dbmeta=con.getMetaData() ;
38 out.print("<br><b>数据库产品:</b>"+dbmeta.getDatabaseProductName());
39 out.print("<br><b>数据库版本:</b>"+dbmeta.getDatabaseProductVersion());
40 out.print("<br><b>用户名:</b>"+dbmeta.getUserName());
41 out.print("<br><b>测试连接成功 ! </b>");
42 try{con.close();}
43 catch(Exception e){}
44 }
45 else
46 out.print("<br><b>连接失败</b>");
47 %>
48 </body>
49 </html>

其中我注释为关键代码的部分是待会儿要替换的。MySQL的用户名和密码要根据你自己的实际情况加以更改。

如果测试成功,则会显示数据库的名称 版本 登录用户 等信息。

把关键部分换成一下代码,就是Oracle的了:

   Connection con=null;
String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
String DBname="jdbc:odbc:你的数据源名";
String DBuser="scott";
String DBcode="tiger";

SQL Server也是一样:

   Connection con=null;
String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
String DBname="jdbc:odbc:你的数据源名";
String DBuser="sa";
String DBcode="123";

方式二:JDBC直连

这种方式需要用到数据库公司为Java专门开发的 jar包,系统里是没有的,得自己下,在文章的最后我会给出下载地址。

MySQL需要用的是 mysql-connector-java-5.1.18-bin.jar 把它拷贝到Tomcat根目录下的 lib文件夹里就好了。

这也就意味着可以使用上述包里的 com.mysql.jdbc.Driver驱动了。以下是测试网页代码:

 1 <%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql.*"%>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <title>连接MySQL</title>
6 </head>
7 <body>
8 <%
9 //以下是关键部分
10 Connection con=null;
11 String DriverName="com.mysql.jdbc.Driver";
12 String DBname="jdbc:mysql://localhost:3306/要连接的数据库名";
13 String DBuser="root";
14 String DBcode="123";
15 ////以上是关键部分
16 try
17 {
18 con=DriverManager.getConnection(DBname,DBuser,DBcode);
19 }
20 catch(SQLException e)
21 {
22 out.print(e.toString());
23 }
24 %>
25 <p><b>JDBC连接数据库测试结果</b></p>
26 <%
27 if(con!=null)
28 {
29 DatabaseMetaData dbmeta=con.getMetaData() ;
30 out.print("<br><b>数据库产品:</b>"+dbmeta.getDatabaseProductName());
31 out.print("<br><b>数据库版本:</b>"+dbmeta.getDatabaseProductVersion());
32 out.print("<br><b>用户名:</b>"+dbmeta.getUserName());
33 out.print("<br><b>测试连接成功 ! </b>");
34 try{con.close();}
35 catch(Exception e){}
36 }
37 else
38 out.print("<br><b>连接失败</b>");
39 %>
40 </body>
41 </html>

测试的结果和方式一类似。

以下是Oracle的关键部分代码:

   Connection con=null;
String DriverName="oracle.jdbc.driver.OracleDriver";
String DBname="jdbc:oracle:thin:@计算机名:1521:数据库实例名";
String DBuser="scott";
String DBcode="tiger";

以下是SQL Server的关键部分代码:

   Connection con=null;
String DriverName="com.microsoft.sqlserver.jdbc.SQLServerDriver";
String DBname="jdbc:sqlserver://localhost;DatabaseName=要连接的数据库名";
String DBuser="sa";
String DBcode="123";

总结:

方式二的优点是整个过程中不需要用到ODBC,更加直接;缺点是需要为不同数据库下载不同的JAR包。

JSP连接数据库的两种方式:Jdbc-Odbc桥和Jdbc直连(转)的更多相关文章

  1. php连接数据库的两种方式- 面向过程 面向对象

    php连接数据库的两种方式- 面向过程 面向对象   一.面向对象1. 链接数据库$conn = @new mysqli("127.0.0.1","root", ...

  2. <%@ include file=""%>与<jsp:include page=""/>两种方式的作用

    一.前言 身为一名coder有太多太多的知识点要去学,太多太多的东西要去记.往往一些小细节也就难免疏忽,但悲催的是多数困恼你的bug就是因为这些微不足道的知识点.我们又不是机器人,怎么可能什么都记得了 ...

  3. 2019/7/18 --1.<%@ include file=""%>与<jsp:include page=""/>两种方式的作用

    一.前言 身为一名coder有太多太多的知识点要去学,太多太多的东西要去记.往往一些小细节也就难免疏忽,但悲催的是多数困恼你的bug就是因为这些微不足道的知识点.我们又不是机器人,怎么可能什么都记得了 ...

  4. ADO.NET连接数据库的两种方式

    //实现了IDisposable接口的类,用using括起来 //插入数据 string connString = "Data Source=(local);Initial Catalog= ...

  5. php连接数据库的两种方式

    一.mysqli方式连接数据库 $mysql_conf = array( 'host' => 'localhost:3306', 'db' => 'ssql', 'db_user' =&g ...

  6. <%@ include file=""%>与<jsp:include page=""/>两种方式的作用以及传值

      一:使用    1.include指令: 1 <%@include file="文件的绝对路径或者相对路径"%> file属性是必填的(绝对或相对路径),但它不支持 ...

  7. 将html页改成jsp的两种方式

    将html页改成jsp的两种方式 作者: 字体:[增加 减小] 类型:转载 时间:2013-08-13 将html页改成jsp有两种方法,第一种是直接修改html文件,另一种是新建jsp文件.下面为大 ...

  8. jsp中的两种跳转方式分别是?有什么区别?

    在JSP中跳转有两种方式 forward跳转:<jsp:forward page ="跳转页面地址"> response跳转:response.sendRedirect ...

  9. 网络协议 finally{ return问题 注入问题 jdbc注册驱动问题 PreparedStatement 连接池目的 1.2.1DBCP连接池 C3P0连接池 MYSQL两种方式进行实物管理 JDBC事务 DBUtils事务 ThreadLocal 事务特性 并发访问 隔离级别

    1.1.1 API详解:注册驱动 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 原因有2个: >导致驱动被注册2 ...

随机推荐

  1. 上传图片到阿里云OSS和获取上传图片的外网url的步骤

    啥都不说  直接上代码 1.html: <form action="/bcis/api/headImgUpload.json" method="post" ...

  2. 快速排序算法(Java)

    快速排序算法的基本思想是:通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另外一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. class Parti ...

  3. A Round Peg in a Ground Hole(凸包应用POJ 1584)

    A Round Peg in a Ground Hole Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5684 Accepte ...

  4. HDU(2089),数位DP

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2089 不要62 Time Limit: 1000/1000 MS (Java/Others ...

  5. Poj(1469),二分图最大匹配

    题目链接:http://poj.org/problem?id=1469 COURSES Time Limit: 1000MS   Memory Limit: 10000K Total Submissi ...

  6. define与typedef 区别

    1)     #define是预处理指令,在编译预处理时进行简单的替换,不作正确性检查,不关含义是否正确照样带入,只有在编译已被展开的源程序时才会发现可能的错误并报错.例如:#define PI 3. ...

  7. Failed to start component [StandardEngine[Catalina].StandardHost[localhost....

    今天我用了近一天的时间研究一个错误,早上写代码是遇到一个 错误严重错误代码如下: 严重: ContainerBase.addChild: start: org.apache.catalina.Life ...

  8. 使用Windows安装的最高版本IE内核加载内嵌页(转载)

    客户端程序内嵌Webbrowser控件时,默认情况都是使用IE7兼容模式打开网页的.但是IE7有很多新的特性不支持,导致无法正常显示出来,所以需要强制使用高版本的IE内核来加载.渲染. void Ch ...

  9. 表结构导出到excel中

    SELECT 表名 = case when a.colorder=1 then d.name else '' end, 表说明 = case when a.colorder=1 then isnull ...

  10. join(添加字符)与id显示

    #!/usr/bin/env python li = ["alex",'sb'] l1 = "_".join(li) print(l1) print(id(li ...