存档

2008年3月 的存档

Oracle故障两例

2008年3月26日

由于在学JSP的过程中会用到Oracle,所以我在自己的机器上装上了Oracle 10g,但是在安装使用过程中遇到两个问题。

1.OracleDBConsole服务不能启动,访问“http://机器名:1158/em”不能进入EM界面,系统事件查看器里面记录“Agent process exited abnormally during initialization.”

  • 网上有很多这个问题的解决方案,我也试了不少,对我这么个Oracle菜鸟来说实在太痛苦了,因为自己不知道怎么解决,所以这个说法要试一试,那个说法也要试试,但是一直没解决,今天终于搞定了,下面给出我的情况的解决方法:
  • 网上解决Oracle服务不能启动最多的做法是修改host文件,即%ORACLE HOME%\db_1\NETWORK\ADMIN\listener.ora文件,修改其中的HOST=内容,我也试了下,但是也没解决,今天我突然发现listener.ora文件中的HOST =XXX的XXX与我的机器名不一致,但是我自从安装oracle之后就没有改变过机器名,但是我还是照着网上的做法修改了HOST=机器名,重新启动OracleDBConsole服务,发现还是不能解决问题,后来我又撤销了修改,把机器名改成了HOST=XXX的XXX,启动服务,发现服务能正常启动,故障排除,后来我想了想可能是因为我在安装Oracle过程中选择的是高级安装模式,而在机器名中使用了默认的localhost而不是自己实际的机器名称,所以会出现这样的问题。

2.在打开EM登陆页面之后,用SYS登陆,发现首页有个错误,提示“java.lang.Exception: Exception in sending Request :: null”,继续上网寻找,在Oracle论坛上终于找到了解决方法:

  • 打开$ORACLE_HOME/<global_db_name>_<db_sid>/sysman/config/emd.properties文件,在其中查找agentTZRegion将后面的GMT修改成你所在时区,比如说agentTZRegion=Asia/Shanghai,重新启动OracleDBConsole服务,OK!
  • 关于时区的列表参考:10.2.0\db_1\sysman\admin\supportedtzs.lst

P.S 512Mb的机器跑Oracle 10g真痛苦!~

alex 工作学习 , , ,

JavaBean语法(下)

2008年3月15日

为什么能通过property="*"的方式,将内容设置到Bean中,其根本原因是使用了Java的反射机制,根据传递参数的名称找到相应的方法,比如,参数名称为name,则自动找到setName方法。

  • 原则:使用JavaBean自动设置内容时,一定要让参数名称与Bean中的属性名称一致,这样通过Java的命名规范,可以达到统一
  • 当需要指定某个属性内容时候,可以在property中指定参数
    • <jsp:setProperty name="sb" property="*"/> 自动匹配,开发中常采用这种做法
    • <jsp:setProperty name="sb" property="name"/>:可以根据自己的需要设置需要的属性值
    • <jsp:setProperty name="sb" property="name" param="password"/>:可以根据自己的需要,任意选择传递参数
    • <jsp:setProperty name="sb" property="name" value="password"/>:根据用户的需要自己设置参数的值
      • 如果输入的值是一个变量,则需要表达式输出

JavaBean取得属性的方法:

  • <jsp:getProperty name="sb" property="name"/>取得属性没有自动匹配

使用JavaBean的setProperty方法可以自动将传递过来的只有数字的字符串变为整形,之后将内容赋值给具体的属性  –>智能

JavaBean的属性范围:

  • page范围:属性只在当前页有效,如果跳转其他页面,则需要重新实例化
    • 适用于:JSP页面操作资源时使用
  • request范围:属性只保存在一次服务器跳转中,前提是使用<jsp:forward>跳转才行
  • session范围:属性保存在一次会话中,可以任意方式连接其他页面,则此对象只实例化一次
  • application范围:属性公有,此对象在整个服务器上只实例化一次。尽量少用因为application会占用资源

alex Java , , , , ,

(九)JDBC操作技术

2008年3月1日

动态WEB的最大特点:可以操作数据库

  • JSP是通过JDBC(Java DataBase Connectivity)技术操作数据库的
  • 使用数据库之后可以发现,对数据的处理由数据库管理系统(DBMS)去完成,而程序只是将需要的数据进行显示

JDBC本身是JAVA连接数据库的一个标准,是JAVA操作数据库的方法,是SUN提供的,而微软操作数据库的方法是ODBC

JDBC 1.0:

  • 分类:
    1. JDBC-ODBC Bridge(JDBC-ODBC桥接方式):因为性能较差,在开发中不采用
    2. JDBC-native Driver Bridge:驱动有个数据库生产厂家提供
    3. JDBC-network Bridge
  • JDBC-ODBC:
    • JDBC-ODBC是在JDK中由SUN本身开发出来的一套数据访问操作,在JDBC-ODBC桥接中它的各种操作API都是最新的,但是性能不高
    • ODBC的基本原理
      • 通过一个数据源名称          —>  数据库
      • 为数据库起了一个别名     —>  程序通过别名访问数据库
      • 即:程序只认别名不认具体的数据库
  • 常用接口:
    1. 使用java.sql包
    2. 常用接口:–DriverManager    –Connection   –Statement   –PreparedStatement     –ResultSet
  • **利用JDBC开发WEB数据库应用框架
    1. 装入JDBC驱动程序
    2. 创建与数据库的连接
    3. 创建语句对象
    4. 利用语句对象执行SQL语句得到结果
    5. 处理结果
    6. JDBC应用结束,关闭各项操作

    阅读全文…

alex Java , , ,

JavaBean语法(上)

2008年3月1日

什么是JavaBean?JavaBean就是一个Java类,即意味着JAVA的一切特性都可以使用,此JavaBean没有图形显示代码,只是完成基本的业务逻辑。

  • JavaBean可以使用Java的封装、继承、多态
  • 使用JavaBean封许多可重复调用的代码–>JavaBean的开发过程是通过项目的不断积累经验的。
  • 使用JavaBean可以达到显示与业务的分离:显示用JSP,业务用JavaBean
    • JAVA开发人员专注于具体业务的开发,而JSP开发人员专注于效果的开发

将JavaBean编译好的*.class文件拷贝到WEB-INF/classes文件夹下,若无此文件夹可以自行建立

编写JavaBean必须需要满足的几点要求:

    1. 所有的JavaBean必须放在同一个包中
    2. JavaBean必须声明成public class类型 –>  文件名称与类名一致
    3. 所有属性必须封装
    4. 设置和取得属性可以通过setter、getter
    5. 使用JSP标签去调用JavaBean必须有一个无参构造方法

JAVA命名规范

  1. 包命名:全部字母小写
  2. 类命名:单词的首字母大写,eg.SimpleBean
  3. 属性名称:第一个单词的首字母小写,之后每单词的首字母大写,eg.studentName
  4. 方法命名:与属性命名相同,eg.public class sayHello(){}
  5. 常量命名:全部单词大写,eg.final String DBDRIVER = "XXXX";

对JAVA程序进行打包编译:javac -d . 文件名

JavaBean开发完成之后在JSP中调用过程:

  1. 使用<%@page import=""%> 使用导入指令
    • 实际上WEB-INF/classes是一个classpath路径,所有的class文件,只要放在此目录下,都可以被访问到
  2. 使用JSP的标签指令调用
    • <jsp:useBean
         id = "sb"                                                               //表示实例化对象的名称
         scope="page"                                                     //表示使用范围
         class="net.hialex.bean.SimpleBean"/>       //对象所属包.类名称路径
    • Tomcat服务器在默认情况下是不能读取修改后的JavaBean如果要读取有以下两种方式:
      1. 重新启动服务器
      2. 配置%TOMCAT_HOME%/conf/web.xml参数reloadable="true"
        • 使用reloadable参数的时机选择:
          • 如果使用这个参数,则表示服务器要始终监视着是否类有改动–这样做影响服务器的性能
          • 在运行时,这个参数必须去掉
          • 在开发时,为了开发方便,可加入此参数

使用JavaBean的好处:

  • 必须结合用户参数提交才能够发现使用JavaBean的好处
  • 使用以下的代码可以替代一切的setter方法调用
    • <jsp:setProperty name = "sb" property="*"/>
      • name:已经声明过的JavaBean对象的id
      • property:表示要设置的属性,如果为"*"则表示自动匹配

alex Java , , , , , ,