进入旧版 | 服务项目 | 成功案例 | 联系方式 | 过客留言 | 友情链接
   
设为首页
加入收藏
联系我们
网站首页 | 新闻资讯 | 操作系统 | 办公软件 | 网络软件 | 工具软件 | 媒体动画 | 网页制作 | 网站开发 | 程序开发 | 平面设计
Photoshop视频教程 | Word入门 | Flash入门 | JScript | VBScript | ASP | PHP | ADO | 网页特效 | 3DS MAX6.0命令 | 系统进程
您当前的位置:GOODSGY电脑学习网 -> 网站开发 -> JSP -> 文章内容  
java JDBC 提高程序可移植性

很多java初学者在开始接触JDBC编程的时候,在网上和大部分的教材上都是这样
介绍JDBC一般的程序:
//可以运行的完整程序
import java.sql.*;

public class DatabaseDemo
{
public static void main(String args[])
{
Connection con;
Statement stmt;
ResultSet rs;

//load the driver class
try
{//直接在程序里面写字符串 com.microsoft.jdbc.sqlserver.SQLServerDriver
//降低了程序的可移植性。
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
}catch(ClassNotFoundException e)
{
System.out.println(e.getMessage());
}

//get database connection ,statement and the ResultSet
try
{
con=DriverManager.getConnection("jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs", "sa", "");

stmt=con.createStatement();
rs=stmt.executeQuery("select * from authors");

while(rs.next())
{
for(int i=1;i<=rs.getMetaData().getColumnCount();i++)
{
System.out.print(rs.getString(i)+" | ");
}
System.out.println();
}
}catch(SQLException e)
{
System.out.println(e.getMessage());
}
}

}
这个程序明显有一个问题,就是程序的可移植性很差,加入我现在不用sql server了,我要使用sybase或orcale
而程序已经大包了,怎么办。在这里我们可以像在vc ado中的 uld文件一样。使用我们的properties文件。把属性和对应的值写入属性文件。例如我们在属性文件 basic.properties 输入一些内容:
connectionURL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs
driverManager:com.microsoft.jdbc.sqlserver.SQLServerDriver
userID:sa
password:
//注意属性与值之间要有一个冒号,英文模式,不是中文冒号。
我们可以通过 java.util包里面的Properties类来读取文件属性的值。

java.util.Properties pro=new java.util.Properties pro();
try
{
pro.load(new FileInputStream("basic.properties"));
}catch(IOException e){.......}
conSql=pro.getProperty("connectionURL");
driverStr=pro.getProperty("driverManager");
userId=pro.getProperty("userID");
password=pro.getProperty("password");
这样我们就可以得到properties中的属性值。当我们的应用程序要改用其他的数据库管理系统的时候我们只要
修改 properties文件就可以了。

把上面的程序完善一些(可以运行的)
/*
AA.java
*/
import java.util.*;
import java.io.*;
import java.sql.*;


public class AA
{
public static void main(String args[])
{
String conSql;
String driverStr;
String userId;
String password;
Connection con;
Statement stmt;
ResultSet rs;
Properties pro=new Properties();;
//load the properties file and get the proterties
try
{

pro.load(new FileInputStream("basic.properties"));

}catch(IOException e)
{
System.out.println(e.getMessage());
}

conSql=pro.getProperty("connectionURL");
driverStr=pro.getProperty("driverManager");
userId=pro.getProperty("userID");
password=pro.getProperty("password");
System.out.println(conSql+"\n"+driverStr+"\n"+userId+"\n"+password);
// load the driver class
try
{
Class.forName(driverStr);
}catch(ClassNotFoundException e)
{
System.out.println(e.getMessage());
}

// get the database connection
try
{
con=DriverManager.getConnection(conSql,userId,password);
String queryStr="select * from authors";
stmt=con.createStatement();
rs=stmt.executeQuery(queryStr);

while(rs.next())
{
for(int i=1;i<=rs.getMetaData().getColumnCount();i++)
{
System.out.print(rs.getString(i)+" | ");
}
System.out.println();
}
}catch(SQLException e)
{
System.out.println(e.getMessage());
}

}

}
注意了::::属性文件要和你的java源文件放在同一个目录下面。



在百度中搜索:java JDBC 提高程序可移植性
在Google中搜索:java JDBC 提高程序可移植性
在Yahoo中搜索:java JDBC 提高程序可移植性

收藏到网摘:新浪VIVI 365key 我摘 POCO网摘 博采中心 YouNote 和讯网摘 天天收藏
[] [返回上一页] [打 印] [收 藏]
下一篇文章:javaCC学习笔记

 相关文章    最新文章
· Linux操作系统下的三种Java环境配置方法
· 面向Java程序员的db4o指南: 数组和集合
· Java与.NET 谁才能主宰未来?
· Java编程技术中汉字问题的分析及解决
· Java 泛型的理解与等价实现
· 在Java中利用JCOM实现仿Excel编程详解
· [图文] Java小技巧:关于Cookie的操作
· Java中消除实现继承和面向接口编程
· Java实战篇:设计自己的Annotation
· 使用Java程序的泛型应该注意的几个地方
 
· 提升JSP页面响应速度的七大秘籍绝招
· 开发一个调试JSP的Eclipse插件
· JSP报表打印的一种简单解决方案
· JSP/Servlet的重定向技术综述
· java的md5加密类(zt)
· 一个用来访问http服务器的东西。功能类似..
· 菜鸟调试手记一(sql server 中文问题)
· Java性能优化技巧集锦(2)
· 用java压缩文件示例(没有中文问题)
· 使用XML/HTC/DHTML模拟标准Windows菜单

∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论…]
站内搜索

精彩图文
  网站导航  
操作系统 办公软件 网络软件
Vista Windows2003 WindowsXP Windows2000/NT Windows9X/ME Linux 其他 Word Excel Powerpoint Outlook 金山系列 其他 网页浏览 上传下载 联络聊天 邮件工具 服务器软件 网络辅助
工具软件 媒体动画 网页制作
系统工具 媒体工具 压缩工具 图文处理 文件管理 其他 3DMAX Authorware Director Maya 视频处理 其他 Flash Dreamweaver FireWorks FrontPage LiveMotion Golive HTML/CSS 其它
网站开发 平面设计 程序设计
ASP JSP PHP CGI JavaScript VBScript XML/SOAP Web服务器 Photoshop PhotoImpact CorelDraw Illustrator Freehand 设计欣赏 其他 VB VC .NET C/C++ DELPHI JAVA

冀ICP备05019428号
Copyright © 2004-2008 电脑学习网 Inc.All rights reserved.
TEL:13832340607
QQ:39873155
E_Mail:goodsgy(#)hotmail.com   (把(#)替换成@)
MSN:goodsgy(#)hotmail.com   (把(#)替换成@)