仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 3176|回复: 19
打印 上一主题 下一主题

[学习教程] JAVA教程之JAVA与数据库毗连办法(一)

[复制链接]
透明 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:38:52 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
java是一种面向对象的编程语言,优点是可移植性比较高,最初设计时就是本着一次编写到处执行设计的。可以开发各种应用程序和游戏,不过速度没有c++快,所以一般是不用java来编写应用程序和电脑游戏。数据|数据库|数据库毗连激活BLOG以后因为比来对照也没写甚么原创文章,如今趁闲的时分写几篇发上往。前段工夫在研讨JAVA与数据库的毗连,发一点履历上往。

用JAVA毗连数据库次要有两种体例,一是用JDBC-ODBC桥来毗连,二是用相干厂商供应的响应驱动程序来毗连,起首谈谈第一种毗连。

JDBC-ODBC桥接器是用JdbcOdbc.Class和一个用于会见ODBC驱动程序的当地库完成的。关于WINDOWS平台,该当地库是一个静态毗连库DLL(JDBCODBC.DLL)。

因为JDBC在计划上与ODBC很靠近。在外部,这个驱动程序把JDBC的办法映照到ODBC挪用上,如许,JDBC就能够和任何可用的ODBC驱动程序举行交互了。这类桥接器的长处是,它使JDBC今朝有才能会见几近一切的数据库。通行体例如图所示:

使用程序---JDBCAPI---JDBC-ODBC---ODBCAPI---ODBC层---数据源

详细操纵办法为:

起首翻开把持面板的办理工具,翻开数据源(ODBC),在用户DSN内里增加数据源(即你要毗连的数据库的名字),在这里假定毗连SQLSERVER2000的GoodsSupply数据库。称号填写你要毗连的数据库的称号(GoodsSupply),然后慢慢设置,假如选用了利用SQL-SERVER暗码认证的话,就要输出响应的用户名及暗码毗连到数据库。一起下一步设置完成。

在JAVA内里编写程序举行测试,在这里我的程序是让用户输出恣意的表名与与列名,把该列的一切数据输入。源代码以下:

importjava.io.BufferedReader;
importjava.io.InputStreamReader;
importjava.sql.*;

publicclassODBCBridge{

publicstaticvoidmain(String[]args){
Stringurl="jdbc:odbc:GoodsSupply";
Statementsm=null;
Stringcommand=null;
ResultSetrs=null;
StringtableName=null;
StringcName=null;
Stringresult=null;
BufferedReaderinput=newBufferedReader(newInputStreamReader(System.in));
try{
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");//加载驱动
}catch(ClassNotFoundExceptione){
System.out.println("CannotloadJdbc-OdbcBridgeDriver");
System.err.print("ClassNotFoundException:");
System.err.println(e.getMessage());
}
Connectioncon=DriverManager.getConnection(url,"USER","PASSWORD");//利用SQL-SERVER2000认证
DatabaseMetaDatadmd=con.getMetaData();//DMD为毗连的响应情形
System.out.println("毗连的数据库:"+dmd.getURL());
System.out.println("驱动程序:"+dmd.getDriverName());
sm=con.createStatement();
System.out.println("输出表名");
tableName=input.readLine();
while(true){
System.out.println("输出列名(为空时程序停止):");
cName=input.readLine();
if(cName.equalsIgnoreCase(""))
break;
command="select"+cName+"from"+tableName;
rs=sm.executeQuery(command);//实行查询
if(!rs.next())
System.out.println("表名或列名输出有误");
else{
System.out.println("查询了局为:");
do
{
result=rs.getString(cName);
//数据库言语设置为中文,不必转换编码
//result=newString(result.getBytes("ISO-8859-1"),"GB2312");
System.out.println(result);
}while(rs.next());
}
}
}catch(SQLExceptionex){
System.out.println("SQLException:");
while(ex!=null){
System.out.println("Message:"+ex.getMessage());
ex=ex.getNextException();
}
}catch(Exceptione){
System.out.println("IOException");
}
}
}



J2ME在手机游戏开发的作用也是无用质疑的。至于桌面程序,可能有人说java不行,界面不好看,但是请看看NetBeans和Eclipse吧,他们都是利用java开发的,而他们的界面是多么的华丽,所以界面决不是java的缺点。还有一个不得不提的优点就是大多java人员都挂在嘴边的java的跨平台性,目前这确实也是java优点之一。
透明 该用户已被删除
沙发
 楼主| 发表于 2015-3-10 13:05:51 | 显示全部楼层
是一种为 Internet发展的计算机语言
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-5-7 21:55

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表