Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台…
2008-02-23 09:43:29来源:互联网 阅读 ()
}
out.println("</table>");
//关闭数据库连结
rs.close();
stmt.close();
con.close();
%>
</body>
</html>
程序代码2:
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.sql.*"%>
<html>
<body>
<%
Class.forName("org.gjt.mm.mysql.Driver").newInstance();
String url ="jdbc:mysql://localhost/chclyb?user=root&password=abcd1001&useUnicode=true&characterEncoding=8859_1";
//testDB为你的数据库名
Connection conn= DriverManager.getConnection(url);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String sql="select * from test";
ResultSet rs=stmt.executeQuery(sql);
while(rs.next()) {%>
第一个字段内容为:<%=rs.getString(1)%>
第二个字段内容为:<%=rs.getString(2)%><br>
<%}%>
<%out.print("数据库操作成功,恭喜你");%>
<%rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
我的以上 2 段代码都能工作。注意以上2段代码的 Class.forName(…) 部分的不同:
Class.forName("com.mysql.jdbc.Driver"); //在程序代码1中
Class.forName("org.gjt.mm.mysql.Driver").newInstance(); //在程序代码2中
程序代码 2 中的代码是为了兼容 mySQL 的老版本而保留的,现在都用 Class.forName("com.mysql.jdbc.Driver"); 驱动了。
以上的代码拷贝到 Tomcat 的虚拟路径下能成功执行吗?恐怕不行。因为还有个重要的事情没有做:需要给 Tomcat5.0 安装 mySQL 的 JDBC 驱动程序!这个问题,网上的大多数文章都没讲,给贴一段连接 mySQL 的代码,就让我们去连接数据库了,连不上的!
mySQL 的驱动需要从网上下载,下载完毕,拷贝到 E:\Tomcat 5.0\common\lib 路径下(我下载下来文件名是mysql-connector-java-3.2.0-alpha-bin.jar),把 Tomcat 服务来个Stop/start 安装就结束了。文件名可以改的,不影响使用,因为这是个压缩包,Tomcat 能自动认识到包里的内容,并把有关类注册进来。前面说的 Class.forName(…) 部分的不同可以在包里找到答案,因为包里正有 com/mysql/jdbc/Driver 和 org/gjt/mm/mysql/Driver 2 个路径,下面放的类文件是一样的。
用 Jsp 连接 Oracle 数据库测试,就好说了,但是同样必须在 E:\Tomcat 5.0\common\lib 路径下拷贝和注册 Oracle 的 JDBC 驱动,这个驱动文件没必要在网上四处打听,显得很菜的样子(我当初就是这样!),这个文件在 Oracle 的 E:\oracle\ora90\jdbc\lib 路径下,文件名是 classes12.jar。我的示例代码如下:
程序代码3:
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.sql.*"%>
<html>
<body>
<%
Class.forName("oracle.jdbc.driver.OracleDriver"); //.newInstance();
String url="jdbc:oracle:thin:@10.0.1.1:1521:mydb"; //mydb为数据库的SID,10.0.1.1 为 数据库服务器 IP
String user="system";
String password="abcd1001";
Connection conn= DriverManager.getConnection(url, user, password);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String sql="select * from test"; //test 是表名,要先建立这个表,再送几条记录
ResultSet rs=stmt.executeQuery(sql);
while(rs.next())
{
%>
第一个字段内容为:<%=rs.getString(1)%>
第二个字段内容为:<%=rs.getString(2)%> <br>
<%
}
out.print("数据库操作成功,恭喜。");
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
关于 Oracle 数据库:我安装的是 Oracle9i 企业版(Windows server 2003 下),安装完毕后,Oracle 将占用 80 端口运行自带的 Apache1.3 Web服务器,还占用 8080 端口运行 TNSLSNR 服务(TNSLSNR.EXE文件在 X:\oracle\ora90\BIN 下),提供一些 log 及文档。所以建议安装 Oracle 的机器就不要安装 IIS 了,如果 IIS 先启动起来,Oracle 的 http 服务就不能启动了。也不能占用 8080 端口。问题是如果还安装 Tomcat,Tomcat 默认正好用的是 8080 端口,所以安装 Tomcat 时最好把端口设成别的值,如 8088。
Oracle 里建立表,必须先建立表空间,还可以加一个数据文件(也可以不加,因为建立表空间时默认已经建了一个数据文件。以后可以视需要再添加)。再建立一个用户(以后的“方案”名和用户名一样)。建立表时,要选择表空间和方案名,最好把表建立在对应的方案下,把他们对应起来,以后好管理。如果把表建立在别的“方案”下,用 SQL*plus 语句访问时要用 [方案].[表名]的格式。
稀稀拉拉说了这么多,是我的一些笔记类的东西。有些东西真的不太懂的,因为刚刚接触了一些非 Microsoft 的东西。希望高手指出我说的和理解不对的地方。新手也不要完全接收我的东西,多想一下,看在您的环境下,我说的能不能调试成功。
我的其他文章在我的个人网站上:“十万个为什么”电脑学习网:http://www.why100000.com。
张庆 zhangking@hotmail.com
http://why100000.com
http://sogo99.com
2005.6.1
上一篇: J2EE初学者需要理解的问题
下一篇: ant 中文手册--介绍
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Java常见面试题(含答案)
下一篇:ant 中文手册--介绍
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash
