首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网页制作-> CSS教程
Java数据库编程中的几个常用技巧-JSP教程,数据库相关
作者:网友供稿 点击:178
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
  1、java数据库操作基本流程

  2、几个常用的重要技巧:

  可滚动、更新的记录集

  批量更新

  事务处理

  java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接

  1、取得数据库连接

  1)用drivermanager取数据库连接

  例子:

string classname,url,uid,pwd;
classname = "oracle.jdbc.driver.oracledriver";
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr;
uid = "system";
pwd = "manager";
class.forname(classname);
connection cn = drivermanager.getconnection(url,uid,pwd);

  2)用jndi(java的命名和目录服务)方式

  例子

string jndi = "jdbc/db";
context ctx = (context) new initialcontext().lookup("java:comp/env");
datasource ds = (datasource) ctx.lookup(jndi);
connection cn = ds.getconnection();

  多用于jsp中

  2、执行sql语句

  1)用statement来执行sql语句

string sql;
statement sm = cn.createstatement();
sm.executequery(sql); // 执行数据查询语句(select)
sm.executeupdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close();

  2)用preparedstatement来执行sql语句

string sql;
sql = "insert into user (id,name) values (?,?)";
preparedstatement ps = cn.preparestatement(sql);
ps.setint(1,xxx);
ps.setstring(2,xxx);
...
resultset rs = ps.executequery(); // 查询
int c = ps.executeupdate(); // 更新

  3、处理执行结果

  查询语句,返回记录集resultset。

  更新语句,返回数字,表示该更新影响的记录数。

  resultset的方法:

  1、next(),将游标往后移动一行,如果成功返回true;否则返回false。

  2、getint("id")或getsting("name"),返回当前游标下某个字段的值。

  3、释放连接。

cn.close();

  一般,先关闭resultset,然后关闭statement(或者preparedstatement);最后关闭connection

  可滚动、更新的记录集

  1、创建可滚动、更新的statement

statement sm = cn.createstatement(resultset.type_scroll_ensitive,resultset.concur_read_only);

  该statement取得的resultset就是可滚动的

  2、创建preparedstatement时指定参数

preparedstatemet ps = cn.preparestatement(sql,resultset.type_scroll_insensitive,resultset.concur_read_only);

resultset.absolute(9000);

  批量更新

  1、statement

statement sm = cn.createstatement();
sm.addbatch(sql1);
sm.addbatch(sql2);
...
sm.executebatch()

  一个statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有

  2、preparedstatement

preparedstatement ps = cn.preparedstatement(sql);
{
 ps.setxxx(1,xxx);
 ...
 ps.addbatch();
}
ps.executebatch();

  一个preparedstatement,可以把一个sql语句,变换参数多次执行,一次更新。

  事务的处理

  1、关闭connection的自动提交

cn.setautocommit(false);

  2、执行一系列sql语句

  要点:执行每一个新的sql语句前,上一次执行sql语句的statement(或者preparedstatemet)必须先close

statement sm ;
sm = cn.createstatement(insert into user...);
sm.executeupdate();
sm.close();

sm = cn.createstatement("insert into corp...);
sm.executeupdate();
sm.close();

  3、提交

cn.commit();

  4、如果发生异常,那么回滚

cn.rollback();


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·ASP.NET with C#使用md5,sha1加密初探-.NET教程,Asp.Net开发
·最简单的java分页算法-JSP教程,Java技巧及代码
·创建ASP.NET WEB自定义控件——例程1-.NET教程,Asp.Net开发
·探究客户端浏览器分辨率的自适应问题(1)-.NET教程,评论及其它
·基于.net开发平台项目案例集锦-.NET教程,Asp.Net开发
·编程初学者的良言警句-ASP教程,脚本编码
·Java中for循环中执行顺序问题及break, continue用法-JSP教程,Java技巧及代码
·Java数据库编程中的几个常用技巧-JSP教程,数据库相关
·ASP.NET2.0中的ClientScriptManager 类用法—如何添加客户端事件-.NET教程,评论及其它
·如何查找、删除表中重复的记录-数据库专栏,SQL Server
最新文章
·google adwords投放报告(二)_网赚技巧
·专访帝国软件的创造者:仍然在路上的80后_站长访谈
·王微:视频网站还要烧钱3年_站长访谈
·个人经验:做站的几大忌讳_站长心得
·大鸟的草根站长seo技巧(一)_站长心得
·flash与后台编码兼容性问题的解决方案_flash教程
·怎样才能把自己的网站做好?一定要知道的定律_站长心得
·论网站设计的十大要点2_站长心得
·网页设计配色应用实例剖析——橙色系2_站长心得
·被k的网站如何改进重新申请通过_google推广
相关主题
  • Java数据报编程之广播-JSP教程,数据库相关
  • Java数据报编程之单播-JSP教程,数据库相关
  • Java数据报编程之组播-JSP教程,Java技巧及代码
  • Java数据报之失序和丢包-JSP教程,Java技巧及代码
  • Java数据报编程之概说-JSP教程,Java技巧及代码
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭