关于包(Package)应用规范的说明

原创 2001年01月16日 08:48:00

一、 dataBase端开发介绍:
package分为两个部分:1、package head,2、package body。前者为包头的定义,后者为过程及方法的实体。只要包头定义中描述足够详细,可以隐藏包体的细节。举例如下:
package head pkg_topnet
is
--user define data type—
--用户自定义数据类型--

   --user define procedure and function—
   --用户自定义过程和函数—
   --the procedure proc_password_validate is the process ofpassword validate—
   --the param log_id is the pa_id coloum—
   --the param log_pass is the pb_yhpwd coloum—
   --the param member_name is the pb_name coloum—
   --if the member_name is return value “none”,it indicate that the—
   --login process has been crash—
   --proc_password_validate过程用于密码的验证—
   --参数log_id为pa_id字段—
   --参数log_pass为pb_yhpwd字段—
   --参数member_name为pb_name字段—
   --如果member_name的返回值为”none”,则说明验证过程出错--
   procedure proc_password_validate(
    log_id in number,
    log_pass in varchar2,
    member_name out varchar2
   );

   --the procedure proc_password_change is the process ofpassword change—
   --the param log_id is the pa_id coloum—
   --the param org_pass is the user’s original password—
   --the param new_pass is the user’s new password—
   --the param status is the status of this process—
   --if the status is return value 0,it indicate that the—
   --change process has been validate—
--if the status is return value 1,it indicate that the—
   --user’s original password make misetake—
   --proc_password_change过程用于密码的修改—
   --参数log_id为pa_id字段—
   --参数org_pass为用户原来的密码—
   --参数new_pass为用户新的密码—
   --参数status为该过程的状态返回值--
   --如果status的返回值为0,则说明修改过程成功—
   --如果status的返回值为1,则说明用户的原始密码有错--
   procedure proc_password_change(
    log_id in number,
    org_pass in varchar2, 
    new_pass in varchar2,
    status out number
   );
  
   end;

因此,我们只需要提供一个规范的包头信息就可以满足大家的开发需要,而包体的详细过程则可以隐藏,当有新的需要时,只需更新包,然后给大家重发一个包头的描述就可以了,在开发阶段中,可以先采用procedure,然后统一将所有的procedure打包,在app端的修改很小,只需要更新三行代码。
二、 appServer端开发解释:
1、 jdbc描述:
package pepper_dog999.UseJdbc;

import java.sql.*;

public class JdbcCallPackage {

  public static void main(String[] args) {
    Connection conn;
    String driver="oracle.jdbc.driver.OracleDriver";
    String url="jdbc:oracle:thin:@192.168.128.41:1521:ORC2";
    try{
      conn=JdbcConnDb.connDb(driver,url,"pepper_dog999","bad_boy2");
      CallableStatement cstmt=conn.prepareCall("{call                      pkg_topnet.proc_password_validate(?,?,?)}");
      cstmt.setInt(1,10001);
      cstmt.setString(2,"pass1");
      cstmt.registerOutParameter(3,Types.VARCHAR);
      cstmt.executeQuery();
      String pbName=cstmt.getString(3);
      System.out.println("the output param is pbName,and its value is:"+pbName);
    }catch(SQLException ex){
      System.out.println("SQL Exception:"+ex.getMessage());
    }
  }
}

class JdbcConnDb {

  public static Connection connDb(String driver,String url,String user,String pass){
    Connection conn=null;
    try{
      Class.forName(driver);
    }catch(java.lang.ClassNotFoundException e){
      System.out.println("Class Not Found Exception:"+e.getMessage());
    }
    try{
      conn=DriverManager.getConnection(url,user,pass);
    }catch(SQLException ex){
       System.out.println("SQL Exception:"+ex.getMessage());
    }
    return(conn);
  }
}

其中类connDb类为自定义类,用来产生一个连接的对象实例。

2、 ODBC中ADO数据模型描述:(各语言根据自身特点调整)
function ConnectOra8(dsn_name,user,password)
 set conn=server.CreateObject("ADODB.Connection")
 conn.Connectionstring="DSN="&dsn_name&";uid="&user&";pwd="&password&";"
 conn.Open
 conn=ConnectOra8("dsn_name","user","password")
  end funcation

  sub ODBCCallPackage()
   const adOpenStatic=3
   const adCmdText=&h0001
   const adCmdStoredProcedure=&H0004
   const adParamInput=&H0001
   const adParamOutput=&H0002
   const adVarChar=200
   const adInteger=3
   const adDate=7
   SQLString="{call pkg_topnet_package.proc_password_validate(?,?,?)}"
   conn=connectOra8("conn_Ora","pepper_dog999","bad_boy2")
   set comm=server.createObject("ADODB.Command")
   with comm
    .activeConnection=conn
    .commandType=adCmdText
    .commandText=SQLString
   end with
   set pa_id=comm.CreateParameter(pa_id,adInteger,adParamInput,12)
 pa_id.value=10001
 comm.parameters.append pa_id
 set pb_yhpwd=comm.CreateParameter(pb_yhpwd,adVarChar,adParamInput,20)
 pb_yhpwd.value="pass1"
 comm.parameters.append pb_yhpwd
 'output
 set pb_name=comm.CreateParameter(pp_name,adVarChar,adParamOutput,20)
 comm.parameters.append pb_name
   comm.execute
   response.write “the output param is member_name and it’s value is”&pb_name
  end sub

三、 优越性描述:
使用统一的包(package)管理可以将开发过程中无序的开发工作协调,而又不会对现有的代码造成太大的改动。其优点如下:
1、 权限的管理:可以由专人管理包的更新,和包头描述的发放,由于隐藏了包体,可以使不太熟悉该开发需求的人很快的上手,因为前端开发的格式可以统一。
2、 性能的改善:可以将核心的过程和性能要求较高的过程封装包体中,对性能提升大有好处。
3、 代码的管理:由于包体和前端程序的分离,当需求改变时可以很快的修改。

Java包(package)的命名规范,java中package命名规则

Java的包名都有小写单词组成,类名首字母大写;包的路径符合所开发的 系统模块的 定义,比如生产对生产,物资对物资,基础类对基础类。以便看了包名就明白是哪个模块,从而直接到对应包里找相应的实现。 ...
  • kongjiea
  • kongjiea
  • 2015年04月29日 14:02
  • 78259

关于包(Package)应用规范的说明

一、 dataBase端开发介绍:package分为两个部分:1、package head,2、package body。前者为包头的定义,后者为过程及方法的实体。只要包头定义中描述足够详细,可以隐藏...
  • pepper_dog999
  • pepper_dog999
  • 2001年01月16日 08:48
  • 510

完全符合package.json在CommonJS中的规范

众所周知,package.json是CommonJS规定的用来描述包的文件,完全符合规范的package.json文件应该含有一下字段。 name:包的名称,必须是唯一的,由小写英文字母、数字和下划线...
  • laijieyao
  • laijieyao
  • 2015年03月12日 20:05
  • 1813

•关于包(package)应用规范的说明-(2013/09/18)

关于包(package)应用规范的说明-(2013/09/18) how to change color of a statu-(2013/09/18) 设计microsoft windows n...
  • q1q2q3q4ln
  • q1q2q3q4ln
  • 2013年09月20日 10:24
  • 442

java--java中的包(package)命名、习惯和注释

1.在eclipse中使用包(package) 首先创建一个新的项目(project),然后开始规划类的目录结构。以汽车为例子。假设现在有3种汽车去,Car,Bus,RaceCar。我们想把Car和...
  • qq_32823673
  • qq_32823673
  • 2017年07月19日 17:07
  • 240

关于@package

经过研究,@package变量,对于framework内部,相当于@protected, 对于framework外部,相当于@privat。 这个特性,很适合用于开发第三方的静态类库,因为多数人并不...
  • waterforest_pang
  • waterforest_pang
  • 2012年06月04日 14:15
  • 4950

程序规范

 程序规范1、 命名中使用英文名称,杜绝使用拼音、英文首字母组合。2、 命名空间、类命名定义采用英文首字母大写,如:UserInfo,接口采用:IUser3、 页面空间命名使用开头3字母前缀。详细见附...
  • superdullwolf
  • superdullwolf
  • 2006年09月22日 18:50
  • 2425

ORACLE PACKAGE 包详解

ORACLE PACKAGE 包 详解 包是一组相关过程、函数、变量、常量#SinaEditor_Temp_FontName、类型和游标等PL/SQL程序设计元素的组合。包具有面向对象设计的特点,是...
  • paul50060049
  • paul50060049
  • 2016年06月19日 22:40
  • 8494

添加新软件到Buildroot

添加新软件到Buildroot 1.创建Config.in文件如下: [python] view plaincopyprint? config BR2_PACKAGE_L...
  • ssdbbg
  • ssdbbg
  • 2012年05月28日 15:28
  • 1911

Java包(package)的命名规范,java中package命名规则

Java的包名都有小写单词组成,类名首字母大写;包的路径符合所开发的 系统模块的 定义,比如生产对生产,物资对物资,基础类对基础类。以便看了包名就明白是哪个模块,从而直接到对应包里找相应的实现。 由...
  • wenghaoduan
  • wenghaoduan
  • 2016年10月29日 09:11
  • 327
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于包(Package)应用规范的说明
举报原因:
原因补充:

(最多只允许输入30个字)