来看JDBC 2.0中的初级数据范例
还得说上一点,就java本质而言,是面相对象的,但是你有没有发现,java也不全是,比如说基本类型,int,那他就是整型而不是对象,转换类型是还得借助包装类。JDBC2.0中供应了对SQL3尺度中引进的新的数据范例,如Blob(binarylargeobject)、Clob(characterlargeobject)、Array对象、REF(对象参考,objectreference)和UDT(用户界说数据范例,user-defineddatatype)等的撑持。这些新的数据范例分离在一同,使得数据库计划职员能够创立更丰厚的形式,并简化了对庞大数据的处置和耐久化。
比方,我们要向tbl_User表中拔出用户的照片,这时候就能够利用流将Blob对象导进数据库中:
Stringsql="intsertintotbl_Uservalues(?,?)";
PreparedStatementpstmt=con.prepareStatement(sql);
Filefile=newFile("C:/images/photo.jpg");
FileInputStreamfis=newFileInputStream(file);
pstmt.setString(1,"John");
pstmt.setBinaryStream(2,fis,(int)file.length());
pstmt.executeUpdate();
pstmt.close();
fis.close();
个中SQL语句的第一个参数为用户名,第二个参数为photo,它是一个Blob型对象。如许在将数据拔出数据库以后,我们就能够用程序猎取该数据了:
Stringsql="selectphotofromtbl_Userwhereusername=?";
PreparedStatementpstmt=con.prepareStatement(selectSQL);
pstmt.setString(1,"John");
ResultSetrs=pstmt.executeQuery();
rs.next();
Blobblob=rs.getBlob("photo");
ImageIconicon=newImageIcon(blob.getBytes(1,(int)blob.length()));
JLabelphoto=newJLabel(icon);
rs.close();
pstmt.close();
相似地,我们也能够对Clob对象举行响应的操纵。上面是一个从ASCII流中间接将Clob对象拔出数据库中的例子:
Stringsql="insertintotbl_Articlesvalues(?,?)";
PreparedStatementpstmt=con.prepareStatement(sql);
Filefile=newFile("C:/data/news.txt");
FileInputStreamfis=newFileInputStream(file);
pstmt.setString(1,"IraqWar");
pstmt.setAsciiStream(2,fis,(int)file.length());
pstmt.executeUpdate();
pstmt.close();
fis.close();
一样,我们也能够用相似的办法将Clob对象从数据库中掏出:
Stringsql="selectcontentfromtbl_Articleswheretitle=?";
PreparedStatementpstmt=con.prepareStatement(sql);
pstmt.setString(1,"IraqWar");
ResultSetrs=pstmt.executeQuery();
rs.next();
Clobclob=rs.getClob("content");
InputStreamReaderin=newInputStreamReader(clob.getAsciiStream());
JTextAreatext=newJTextArea(readString(in));
rs.close();
pstmt.close();
C++编译的是本地码,优点是启动快,而且可以精确控制资源因此可以开发很高效的程序.缺点是编程麻烦,而且容易留下安全隐患.跨平台靠源代码在各个平台间分别编译(一处编写到处编译) 接着就是EJB了,EJB就是Enterprise JavaBean, 看名字好象它是Javabean,可是它和Javabean还是有区别的。它是一个体系结构,你可以搭建更安全、更稳定的企业应用。它的大量代码已由中间件(也就是我们常听到的 Weblogic,Websphere这些J2EE服务器)完成了,所以我们要做的程序代码量很少,大部分工作都在设计和配置中间件上。 多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。 让你能够真正掌握接口或抽象类的应用,从而在原来的Java语言基础上跃进一步,更重要的是,设计模式反复向你强调一个宗旨:要让你的程序尽可能的可重用。 那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧! 设计模式是高级程序员真正掌握面向对象核心思想的必修课。设计模式并不是一种具体"技术",它讲述的是思想,它不仅仅展示了接口或抽象类在实际案例中的灵活应用和智慧 是一种为 Internet发展的计算机语言 有时间再研究一下MVC结构(把Model-View-Control分离开的设计思想) http://www.jdon.com/去下载,或到同济技术论坛的服务器ftp://nro.shtdu.edu.cn去下,安装上有什么问题,可以到论坛上去提问。 自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。 一直感觉JAVA很大,很杂,找不到学习方向,前两天在网上找到了这篇文章,感觉不错,给没有方向的我指了一个方向,先不管对不对,做下来再说。 是一种语言,用以产生「小应用程序(Applet(s)) Java是一种计算机编程语言,拥有跨平台、面向对java
页:
[1]