DB2数据库、触发器、存储过程、JAVA数据库链接(JDBC)、调用层接口(CLI)

news/2024/5/18 22:59:16 标签: 数据库, jdbc, db2, 存储, java, string
触发器
   建一个触发器,应包含以下部分:
   触发器名字
   触发器触发事件: insert,delete,update
   激活时间: before,after
   粒度: for each statement,for each row
   过渡变量:
        old row:表示触发事件之前被修改的值:
        new row表示触发事件之后被修改的值
        old table表示触发事件之前全部被修改行的一个只读假想表
        new table表示触发事件之后全部被修改行的一个假想表
   触发条件: 由WHEN开始,可包含一个或多个谓词,可包含过渡变量和子查询
   触发体: 由一个或多个SQL语句组成
例:
      CREATE TRIGGER REORDER
      AFTER UPDATE OF ON_HAND, MAX_STOCKED ON PARTS
      REFERENCING NEW AS N_ROW
      FOR EACH ROW MODE DB2SQL
      WHEN (N_ROW.ON_HAND < 0.10 * N_ROW.MAX_STOCKED
      AND N_ROW.ORDER_PENDING = 'N')
      BEGIN ATOMIC
        VALUES(ISSUE_SHIP_REQUEST(N_ROW.MAX_STOCKED -
                                  N_ROW.ON_HAND,
                                  N_ROW.PARTNO));
        UPDATE PARTS SET PARTS.ORDER_PENDING = 'Y'
        WHERE PARTS.PARTNO = N_ROW.PARTNO;
      END
 存储过程
    存储过程主要通过”Stored Procedure Builder”来建立,
(一)对存储过程的调用分三部分:
1.连接(与数据库建立连接)
       Class.forName("COM.ibm.db2.jdbc.net.DB2Driver").newInstance();
       Connection con=DriverManager.getConnection(url,user,password);
2。注册输出参数
       cs.registerOutParameter (3, Types.INTEGER);
3。调用存储过程:
       CallableStatement cs=con.prepareCall("{call store_name(参数,参数,参数)}");
(二)调用举例:
import java.net.URL;
import java.sql.*;
class test2
{
   public static void main(String args[])
   {
     String url = "jdbc:db2://wellhope/sample";
     String user="db2admin";
     String password="db2admin";
     try
     {
       Class.forName("COM.ibm.db2.jdbc.net.DB2Driver").newInstance();
      
       //与数据库建立连接
       Connection con=DriverManager.getConnection(url,user,password);
      
       checkForWarning(con.getWarnings());
       DatabaseMetaData dma=con.getMetaData();
       String str="This is a string";
       //int hashcode=str.hashCode();
       //System.out.println("Hashcode   "+hashcode);
       //创建Statement对象,用于执行SQL语句
       Statement stmt=con.createStatement();
       //创建CallableStatement对象,用于执行存储过程
       CallableStatement cs=con.prepareCall("{call PRO_YHDL1(?,?,?)}");
       //注册输出参数
       cs.registerOutParameter (3, Types.INTEGER);
       int result = 0;
       cs.setString(1,"123");
       cs.setString(2,"123");
       cs.execute();
       result = cs.getInt (3);
       dispResultSet(result);
       cs.close();
       con.close();
     }
     catch(SQLException ex)
     {
       System.out.println(" * * * SQLException caught * * * ");
      
       while(ex!=null)
       {
          System.out.println("SQLState: "+ex.getSQLState());
          System.out.println("Message: "+ex.getMessage());
          System.out.println("Vendor: "+ex.getErrorCode());
          ex=ex.getNextException();
          System.out.println("");
       }
     }   
     catch(java.lang.Exception ex)
     {    
       ex.printStackTrace();
     }
}
(三)存储过程举例:
     Pro_yhdl1是一个存储过程,它的功能是从数据库表YHDL中取出PWD:
import java.sql.*;                  
public class Pro_yhdl1
{
    public static void pro_yhdl1 ( String m_id,
                                   String m_pwd,
                                   int[] result ) throws SQLException, Exception
    {
        // Get connection to the database
        Connection con = DriverManager.getConnection("jdbc:default:connection");
        PreparedStatement stmt = null;
        ResultSet rs = null;
        String sql;
        String m_password="";
        sql = "SELECT"
             + "       DB2ADMIN.YHDL.PWD"
            + " FROM"
            + "    DB2ADMIN.YHDL"
            + " WHERE"
            + "    ("
            + "       ( "
            + "          DB2ADMIN.YHDL.ID = '"+m_id.trim()+"'"
            + "       )"
             + "    )";
        stmt = con.prepareStatement( sql );
        rs = stmt.executeQuery();
        // Access query results
        while (rs.next())
        {
           m_password=rs.getString(1);
           m_password=m_password.trim();
           if (rs.wasNull())
              System.out.print("NULL");
           else
             System.out.print(m_password);
         }
        if(m_password.equals(m_pwd.trim()))
        {
          result[0] =1;
        }
        else
        {
          result[0] =0;
        }
        // close open resources
        if (rs != null) rs.close();
        if (stmt != null) stmt.close();
        if (con != null) con.close();
        // set return parameter
        //result[0] = result[0];
    }
}
 JAVA数据库链接(JDBC)
   DB2 的 Java 支持包括 JDBC,一个以供应商为中心的动态 SQL 接口,它通过标准的 Java方法提供对应用程序的数据存取。JDBC 与 DB2 CLI 相似之处在于您不必预编译或联编 JDBC 程序。使用 JDBC 编写的应用程序只使用动态 SQL。
JDBC编程步骤:
1建立与数据库的连接:
       Class.forName("Com.ibm.db2.jdbc.net.DB2Driver");
       connection con=DriverManager.getConnection(url);
2.创建Statement对象:
       Statement stmt=con.createStatement();
3执行查询语句:
       ResultSet rs=stmt.execQuery("SQL语句");
4.获取和设置选项:
       ResultSetMetaData rsmd=rs.getMetaData();
       int numCols=rsmd.getColumnCount()获取结果集总列数;
       rsmd.getColumnLabel(i))获取记录值;
       setMaxRows :设置结果集能容纳的最多行数.
       setQueryTimeout:设置一个语句执行等待的时间.
       setEscapeProcessing:通知驱动程序如何处理转义字符.
5.关闭Statement
       stmt.clost();
 调用层接口(CLI)
    CLI不是一种新的查询语言,它只不过是应用程序可利用SQL语句去提交事务处理的一种简单接口,对数据库的查询和修改,仍要使用SQL语言编写,包括CLI函数的调用。
    调用层接口(CLI)为DB2所提供的处理动态SQL语句的两种机制之一,即在应用程序首次运行时,动态SQL语句提交给数据库系统,CLI依赖一组函数调用,可嵌入主语言中.


from :   http://blog.csdn.net/yuejingjiahong/article/details/6669097


http://www.niftyadmin.cn/n/1099917.html

相关文章

IntelliJ IDEA优秀插件(编程通用)

转自&#xff1a;http://blog.csdn.net/sujun10/article/details/72852939 一、IntelliJ IDEA开发 最近大部分开发IDE工具都切换到了&#xff0c;所以也花了点心思去找了相关的插件。这里整理的适合各种语言开发的通用插件&#xff0c;也排除掉IntelliJ IDEA自带的常用插件了&a…

TCP/IP协议详解(二):建立和关闭连接

标签&#xff1a; tcp 2016-06-15 20:20 778人阅读 评论(0) 收藏 举报 本文章已收录于&#xff1a; 分类&#xff1a; TCP-IP&#xff08;1&#xff09; 作者同类文章X版权声明&#xff1a;本文为博主原创文章&#xff0c;未经博主允许不得转载。 目录(?)[] TCP状态机sequ…

AIX常用命令2

常用的一些aix的命令&#xff1a; (1)关于 if 的参数 [ -a FILE ] 如果 FILE 存在则为真。 [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真。 [ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真。 [ -d FILE ] 如果 FILE 存在且是一个目录则为真。 [ -e FILE ]…

TCP/IP详解学习笔记(1)-基本概念

为什么会有TCP/IP协议 在世界上各地&#xff0c;各种各样的电脑运行着各自不同的操作系统为大家服务&#xff0c;这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音&#xff0c;让他们无法合作一样。计算机使用者意识到&#xff0c;计…

常见DB2命令

连接数据库&#xff1a; connect to [数据库名] &#xff1b; --本地数据库 connect to [数据库名] user [操作用户名] using [密码]&#xff1b; --远程数据库 创建缓冲池(8K)&#xff1a; create bufferpool ibmdefault8k IMMEDIATE SIZE 5000 P…

TCP/IP详解学习笔记(2)-数据链路层

数据链路层有三个目的&#xff1a; 为IP模块发送和 接收IP数据报。 为ARP模块发送ARP请求和接收ARP应答。 为RARP发送RARP请 求和接收RARP应答 ip大家都听说过。至于ARP和RARP&#xff0c;ARP叫做地址解析协议&#xff0c;是用IP地址换MAC地址的一种协议&#xff0c;而RARP则叫…

bit、byte、位、字节、汉字、字符

bit、byte、位、字节、汉字的关系 1 bit 1 二进制数据 1 byte 8 bit 1 字母 1 byte 8 bit 1 汉字 2 byte 16 bit 1. bit&#xff1a;位 一个二进制数据0或1&#xff0c;是1bit&#xff1b; 2. byte&#…

Spring Boot中使用使用Spring Security和JWT

目标 1.Token鉴权 2.Restful API 3.Spring SecurityJWT 开始 自行新建Spring Boot工程 引入相关依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId><version>1.5.9.REL…