学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. snackbar初体验

    底部弹出的部分就是snackbar的,右侧可添加一个action响应点击事件,遗憾的时貌似只能添加一个 这是华为mate8上面运行出来的效果,颜色之类的都是默认.不同的android版本样式稍有差异 ...

  2. 判断listview是上滑还是下滑的方法

    方法一: 用setOnScrollListener(new AbsListView.OnScrollListener())来实现,判断滑动后显示的第一个条目 ,与滑动前的第一个条目的大小来判断, 这种 ...

  3. Oracle中instr 函数的详解

    INSTR    (源字符串, 目标字符串, 起始位置, 匹配序号)    在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置.只检索一次,就是说从字符的开始    到字 ...

  4. [ios][opengles]opengles纹理贴图

    参考:http://www.cnblogs.com/andyque/archive/2011/09/02/2155061.html

  5. class打包成exe方式

    首先运行dos命令 jar -cvf **.jar *.class 把所有文件打包成jar包 用解压器打开jar包 打开meta-inf文件夹 打开用记事本打开main.mf文件 增加语句Main-C ...

  6. sscanf 函数 分类: POJ 2015-08-04 09:19 4人阅读 评论(0) 收藏

    sscanf 其实很强大 分类: 纯C技术 技术笔记 2010-03-05 16:00 12133人阅读 评论(4) 收藏 举报 正则表达式stringbuffercurlgoogle 最近在做日志分 ...

  7. 局部内部类访问方法中的局部变量为什么加final

    转载:http://www.cnblogs.com/mjblogs/p/4971630.html 1)从程序设计语言的理论上:局部内部类(即:定义在方法中的内部类),由于本身就是在方法内部(可出现在形 ...

  8. lua注释

    1. 单行注释 --  功能等同于C++中的// 2. 多行注释  --[[  注释的内容  ]]   功能等同于C++中的 /**/ 3. 多行注释   --[====[   注释和内容  ]=== ...

  9. Intellij IDEA svn的使用记录

    这里的忽略一直灰色的,可以进入 这里的版本控制里进行忽略选择 或者 这里进行添加 这里有三个选择 按照顺序 1.忽略指定的文件 2.忽略文件夹下所有文件 3.忽略符合匹配规则的文件 到Commit C ...

  10. Datagrid扩展方法InitEditGrid{支持单元格编辑}

    //-----------------------------------------------------------------/******************************** ...