仓酷云

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

[学习教程] 来看JDBC中Statement,PreparedStatement,CallableStatement三个办法的实例

[复制链接]
活着的死人 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:13:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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

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

x
而学习JAVA我觉得最应该避免的就是:只学习,不思考,只记忆,不实践!
publicvoidListStudents()throwsSQLException{
 inti,NoofColumns;
 StringStNo,StFName,StLName;
 //初始化并加载JDBC-ODBC驱动程序
 Class.forName("jdbc.odbc.JdbcOdbcDriver");
 //创立毗连对象
 ConnectionEx1Con=DriverManager.getConnection("jdbc:odbc:StudentDB";uid="admin";pw="sa");
 //创立一个复杂的Statement对象
 StatementEx1Stmt=Ex1Con.createStatement();
 //创立SQL串,传送到DBMS并实行SQL语句
 ResultSetEx1rs=Ex1Stmt.executeQuery("SELECTStudentID,FirstName,LastNameFROMStudents");
 //处置每个数据行,直到不再无数据行
 System.out.println("StudentNumber  FirstName  LastName");
 while(Ex1rs.next()){
 //将列值保留到java变量中
 StNo=Ex1rs.getString(1);
 StFName=Ex1rs.getString(2);
 StLName=Ex1rs.getString(3);
 System.out.println(StNo,StFName,StLName);
 }
}
publicvoidUpdateStudentName(StringStFName,StringStLName,StringStNo)throwsSQLException,ClassNotFoundException
{
 intRetValue;
 //初始化并加载JDBC-ODBC驱动程序
 Class.forName("jdbc.odbc.JdbcOdbcDriver");
 //创立毗连对象
 ConnectionEx1Con=DriverManager.getConnection("jdbc:odbc:StudentDB";uid="admin";pw="sa");
 //创立一个复杂的Statement对象
 StatementEx1Stmt=Ex1Con.createStatement();
 //创立SQL串,传送到DBMS并实行该SQL语句
 StringSQLBuffer="UPDATEStudentsSETFirstName="+
 StFName+",LastName="+StLName+
 "WHEREStudentNumber="+StNo;
 RetValue=Ex1Stmt.executeUpdate(SQLBuffer);
 System.out.println("Updated"+RetValue+"rowsintheDatabase.");
}
//利用PreparedStatement改善实例
//Declareclassvariables
ConnectionCon;
PreparedStatementPrepStmt;
booleanInitialized=false;
publicvoidInitConnection()throwsSQLException,ClassNotFoundException{
 //InitializeandloadtheJDBC-ODBCdriver.
 Class.forName("jdbc.odbc.JdbcOdbcDriver");
 //Maketheconnectionobject.
 Con=DriverManager.getConnection("jdbc:odbc:StudentDB";uid="admin";pw="sa");
 //CreateapreparedStatementobject.
 PrepStmt=Con.prepareStatement("SELECTClassName,Location,DaysAndTimesFROMClassesWHEREClassName=?");
 Initialized=true;
}
publicvoidListOneClass(StringListClassName)throwsSQLException,ClassNotFoundException{
 inti,NoOfColumns;
 StringClassName,ClassLocation,ClassSchedule;
 if(!Initialized){
 InitConnection();
 }

 //SettheSQLparametertotheonepassedintothismethod
 PrepStmt.setString(1,ListClassName);
 ResultSetEx1rs=PrepStmt.executeQuery();
 //Processeachrowuntiltherearenomorerowsanddisplaytheresultsontheconsole.
 System.out.println("ClassLocationSchedule");
 while(Ex1rs.next()){
 ClassName=Ex1rs.getString(1);
 ClassLocation=Ex1rs.getString(2);
 ClassSchedule=Ex1rs.getString(3);
 System.out.println(ClassName,ClassLocation,ClassSchedule);
 }
}
//利用CallableStatement显现成就
//事后界说好的存储历程的挪用情势为:studentGrade=getStudentGrade(StudentID,ClassID)
publicvoidDisplayGrade(StringStudentID,StringClassID)throwsSQLException
{
 intGrade;
 //InitializeandloadtheJDBC-ODBCdirver.
 Class.forName("jdbc.odbc.JdbcOdbcDriver");
 //Maketheconnectionobject;
 ConnectionCon=DriverManager.getConnection("jdbc:odbc:studentDB";uid="admin";pw="sa");
 //CreateaCallableStatementobject;
 CallableStatementCStmt=Con.prepareCall({?=callgetStudentGrade[?,?]});

 //Nowtietheplaceholderswithactualparameters.
 //Registerthereturnvaluefromthestoredprocedure
 //asanintegertypesothatthedriverknowshowtohandleit.
 //Notethetypeisdefinedinthejava.sql.Types.
 CStmt.registerOutParameter(1,java.sql.Types.INTEGER);

 //SettheInparameters(whichareinheritedfromthePreparedStatementclass)
 CStmt.setString(1,StudentID);
 CStmt.setString(2,ClassID);

 //Nowwearereadytocallthestoredprocedure

 intRetVal=CStmt.excuteUpdate();

 //GettheOUTParameterfromtheregisteredparameter
 //NotethatwegettheresultfromtheCallableStatementobject
 Grade=CStmt.getInt(1);

 //Anddisplaytheresultsontheconsole;
 System.out.println("TheGradeis:"+Grade);
}

学习JAVA的目的更多的是培养自身的工作能力,我觉得工作能力的一个核心就是:独立思考能力,因为只有独立思考后,才会有自己的见解
沙发
发表于 2015-1-20 17:23:00 来自手机 | 只看该作者
你快去找一份Java的编程工作来做吧(如果是在校学生可以去做兼职啊),在实践中提高自己,那才是最快的。不过你得祈祷在公司里碰到一个高手,而且他 还愿意不厌其烦地教你,这样好象有点难哦!还有一个办法就是读开放源码的程序了。我们知道开放源码大都出自高手,他们设计合理,考虑周到,再加上有广大的程序员参与,代码的价值自然是字字珠叽,铿锵有力(对不起,偶最近《金装四大才子》看多了)。
柔情似水 该用户已被删除
板凳
发表于 2015-1-25 10:10:15 | 只看该作者
是一种突破用户端机器环境和CPU
爱飞 该用户已被删除
地板
发表于 2015-1-25 23:11:24 | 只看该作者
Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针(以引用取代)、运算符重载(operator overloading)
兰色精灵 该用户已被删除
5#
发表于 2015-2-1 09:39:45 | 只看该作者
Java自面世后就非常流行,发展迅速,对C++语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台
若相依 该用户已被删除
6#
发表于 2015-2-7 02:04:29 | 只看该作者
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
精灵巫婆 该用户已被删除
7#
发表于 2015-2-11 08:41:01 | 只看该作者
Java语言支持Internet应用的开发,在基本的Java应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI(远程方法激活)机制也是开发分布式应用的重要手段。
透明 该用户已被删除
8#
发表于 2015-3-2 04:53:42 | 只看该作者
你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
蒙在股里 该用户已被删除
9#
发表于 2015-3-11 02:08:34 | 只看该作者
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
因胸联盟 该用户已被删除
10#
发表于 2015-3-13 10:09:57 | 只看该作者
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
若天明 该用户已被删除
11#
发表于 2015-3-17 18:46:01 | 只看该作者
一般学编程语言都是从C语开始学的,我也不例外,但还是可能不学过程语言而直接学面向对象语言的,你是刚接触语言,还是从C开始学比较好,基础会很深点,如果你直接学习JAVA也能上手,一般大家在学语言的时候都记一些语言的关键词,常有的包和接口等。再去做逻辑代码的编写,以后的学习过程都是从逻辑代码编写中提升的,所以这方面都是经验积累的。你要开始学习就从
小女巫 该用户已被删除
12#
发表于 2015-3-24 19:16:18 | 只看该作者
如果你学过HTML,那么事情要好办的多,如果没有,那你快去补一补HTML基础吧。其实JSP中的Java语法也不多,它更象一个脚本语言,有点象ASP。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-9-28 19:19

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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