使用Java语言开发存储过程
如何用Java编写一个简单的数据库应用程序
如何用Java编写一个简单的数据库应用程序Java是一个非常强大的编程语言,它提供了多种处理数据库的方案。
下面我们将介绍如何用Java编写一个简单的数据库应用程序。
1.安装Java开发环境(JDK):首先,你需要安装Java开发环境(Java Development Kit,JDK)。
你可以从Oracle官方网站上下载最新版本的JDK,并按照它们提供的说明进行安装。
2.设置环境变量:一旦JDK安装完毕,你需要设置相应的环境变量。
在Windows系统中,你可以在“系统属性”中找到“高级”选项卡,点击“环境变量”,并添加JAVA_HOME变量指向JDK的安装路径。
3.下载并安装数据库:Java支持多种数据库,例如MySQL、Oracle和PostgreSQL。
你可以选择其中一个作为你的数据库。
在这个教程中,我们将使用MySQL作为示范。
从MySQL官方网站下载并安装最新版本的MySQL。
4.连接数据库:一旦数据库安装完毕,你需要编写Java代码来连接数据库。
首先,你需要下载MySQL JDBC驱动程序。
你可以从MySQL官方网站上找到最新版本的驱动程序,并将其添加到你的项目中。
接下来,你需要使用编程语言的`import`语句将这个驱动程序导入到你的Java代码中。
5.建立数据库连接:在你的Java代码中,你需要使用JDBC驱动程序提供的API来建立数据库连接。
这包括创建一个Connection对象,并传入数据库的URL、用户名和密码。
```javaimport java.sql.*;public class Main {public static void main(String[] args) {String url = "jdbc:mysql://localhost:3306/mydatabase";String user = "root";String password = "mypassword";try {Connection conn = DriverManager.getConnection(url, user, password);System.out.println("Connected to the database");} catch (SQLException e) {System.out.println("An error occurred");e.printStackTrace();}}}```在上面的代码中,`url`变量指定了数据库的URL,`user`和`password`变量指定了连接数据库所需的用户名和密码。
存储过程调用java代码的方法
存储过程调用java代码的方法存储过程是一组SQL语句的集合,可以被视为一种预编译的SQL 语句,可以通过存储过程调用来实现对数据库的操作。
在Java中,我们可以通过以下方法来调用存储过程:1. 使用JDBC调用存储过程使用JDBC调用存储过程需要以下步骤:1)获取数据库连接。
2)创建CallableStatement对象,使用存储过程名称作为参数创建对象。
3)设置输入参数和输出参数。
输入参数可以通过setXXX()方法设置,输出参数可以使用registerOutParameter()方法注册。
4)执行存储过程。
可以使用execute()或executeUpdate()方法执行。
5)获取输出参数。
以下是一个简单的示例:```try(Connection conn = DriverManager.getConnection(url, user, password)) {CallableStatement cs = conn.prepareCall('{call procedure_name(?, ?)}');cs.setInt(1, 1); // 设置输入参数cs.registerOutParameter(2, Types.VARCHAR); // 注册输出参数cs.execute(); // 执行存储过程String result = cs.getString(2); // 获取输出参数System.out.println(result);} catch (SQLException e) {e.printStackTrace();}```2. 使用ORM框架调用存储过程使用ORM框架调用存储过程需要根据不同的框架进行配置。
以下是使用MyBatis调用存储过程的示例:1)在Mapper XML文件中定义存储过程调用语句。
```<select id='callProcedure' statementType='CALLABLE'>{call procedure_name(#{param1, mode=IN,jdbcType=INTEGER}, #{param2, mode=OUT, jdbcType=VARCHAR})}</select>```2)在Java代码中调用Mapper方法。
oracle存储过程调用javasource的方法
oracle存储过程调用javasource的方法Oracle存储过程调用Java方法介绍在Oracle数据库中,我们可以使用存储过程来执行一系列的数据库操作。
有时候,我们希望在存储过程中调用Java方法,以实现一些比较复杂的逻辑。
本文将详细介绍在Oracle存储过程中调用Java方法的几种方法。
方法一:使用Java Stored ProcedureJava Stored Procedure是Oracle数据库提供的一种特殊的存储过程类型,在该类型的存储过程中可以直接调用Java方法。
步骤:1.创建Java类,并将其编译成字节码文件(.class文件)。
2.将字节码文件导入到数据库中,可以使用loadjava工具或通过SQL语句执行导入。
3.创建Java Stored Procedure,将其指定为刚导入的字节码文件,并编写实际的存储过程逻辑。
4.在需要的地方调用Java Stored Procedure。
优点:•简单易用,只需创建Java类和Java Stored Procedure即可。
•可以直接访问数据库,无需通过其他方式。
缺点:•必须将Java类编译成字节码文件并导入到数据库中,稍显麻烦。
•Java Stored Procedure在数据库中运行,可能会造成数据库性能的损耗。
方法二:使用外部过程调用Java方法Oracle数据库通过提供外部过程功能,允许我们在存储过程中调用外部的Java方法。
步骤:1.将Java方法包装成Java函数或Java过程,并将其编译成动态加载库文件(.so或.dll文件)。
2.使用CREATE LIBRARY语句在数据库中创建对应的外部库。
3.创建存储过程,将其指定为调用外部库中的函数或过程,并编写实际的存储过程逻辑。
4.在需要的地方调用存储过程。
优点:•可以方便地调用已存在的Java方法,无需修改原有代码。
•外部过程在数据库外部运行,不会对数据库性能造成影响。
JAVA通过MyBatis调用MySql存储过程和函数
JAV A通过MyBatis调用MySql存储过程和函数1.引言无论是采用SPRING MVC框架开发WEB画面,还是开发需按一定时间间隔执行的批处理,都可能要调用数据库的存储过程或函数。
其间调用参数设置不正会浪费大量调试时间初学者甚至放弃使用存储过程。
本文记录了通过MyBatis调用MySql存储过程和函数的具体参数设置内容,供参考。
2.MySql存储过程例/*全公司员工下一年度带薪休假一发赋予处理*/CREATE DEFINER=`DBuser`@`%` PROCEDURE `paid_vacation_compute `( OUT p_返回值 INT(11) ,INOUT p_员工号 CHAR(3) ,p_操作者ID VARCHAR(3))PROC_START:BEGIN/* 变量声明 */DECLARE done INT; #异常退出控制变量DECLARE empNo CHAR(3); #员工号DECLARE dateHire date; #分公司就职日DECLARE workYears INT; #集团内工作年数DECLARE lastYearRemainDays FLOAT; #昨年残日数(允许以小时为单位休假)DECLARE nowYearleaveDays FLOAT; #今年休暇日数(允许以小时为单位休假)DECLARE elapseYear INT; #入集团经过年度数/* 游标声明 */#上年带薪休假数据DECLARE staffPaidVacationDaysCur CURSOR FORSELECT a.EMP_NO, #员工号a.DATE_HIRE, #入职日期a.WORK_YEARS, #工作年限b.REMAIN_DAYS # 上年带薪休假应休但未休残日数FROM T_EMPLOYEE AS a,T_PAID_VACATION AS bWHERE a. EMP_NO = b. EMP_NO/* 程序退出规定声明 */DECLARE CONTINUE HANDLER FOR NOT FOUND SET SET done = 1;DECLARE EXIT HANDLER FOR SQLWARNING SET done = 2;DECLARE CONTINUE HANDLER FOR SQLEXCEPTIONBEGINSET done = 3;ROLLBACK; #SQL异常回滚END;/* 1.输入参数妥当性检查 */IF (p_操作者 IS NULL OR p_操作者 = '') THENSET p_返回值 = 9;LEAVE PROC_START;END IF;SET done = 0;START TRANSACTION;loop_label:LOOP# 读入一条记录, 代入到各个变量中FETCH staffPaidVacationDaysCurINTO empNo, #员工号dateHire, #就职日workYears, #集团内工作年数lastYearRemainDays #昨年残日数;IF done = 1 THENLEAVE loop_label;END IF;/*根据集团内工作年限+分公司就职年限计算下一年度带薪天数*/ SET elapseYear = YEAR(current_timestamp)- Year(dateHire)+ workYears;IF elapseYear = 0 THENSET nowYearLeaveDays = 10;ELSEIF elapseYear = 1 THENSET nowYearLeaveDays = 11;ELSEIF elapseYear = 2 THENSET nowYearLeaveDays = 12;ELSEIF elapseYear = 3 THENSET nowYearLeaveDays = 14;ELSEIF elapseYear = 4 THENSET nowYearLeaveDays = 16;ELSEIF elapseYear = 5 THENSET nowYearLeaveDays = 18;ELSEIF elapseYear >= 6 THENSET nowYearLeaveDays = 20;END IF;SET done = 0;SET p_员工号= empNo;UPDATE T_PAID_VACATIONSETLAST_YEAR_REMAIN_DAYS = lastYearRemainDays,THIS_YEAR_BASE_DAYS = nowYearLeaveDays,UPDATE_DATETIME = current_timestamp,UPDATE_USER_ID = 'SYS',UPDATE_TERMINAL_ID = 'MANUAL'WHERE EMP_NO = CONVERT(empNo USING binary);IF done = 3 THENSET p_返回值 = 6;LEAVE PROC_START;END IF;END LOOP;COMMIT;END3.MySql函数例CREATE DEFINER=`DBuser`@`%` FUNCTION ` paid_vacation_compute `( p_员工号 CHAR(3) ,p_操作者ID VARCHAR(3))) RETURNS int(11)BEGIN/* 变量声明 */DECLARE done INT; #异常退出控制变量DECLARE empNo CHAR(3); #员工号DECLARE dateHire date; #分公司就职日DECLARE workYears INT; #集团内工作年数DECLARE lastYearRemainDays FLOAT; #昨年残日数(允许以小时为单位休假)DECLARE nowYearleaveDays FLOAT; #今年休暇日数(允许以小时为单位休假)DECLARE elapseYear INT; #入集团经过年度数/* 游标声明 */#上年带薪休假数据DECLARE staffPaidVacationDaysCur CURSOR FORSELECT a.EMP_NO, #员工号a.DATE_HIRE, #入职日期a.WORK_YEARS, #工作年限b.REMAIN_DAYS # 上年带薪休假应休但未休残日数FROM T_EMPLOYEE AS a,T_PAID_VACATION AS bWHERE a. EMP_NO = b. EMP_NO/* 程序退出规定声明 */DECLARE CONTINUE HANDLER FOR NOT FOUND SET SET done = 1;DECLARE EXIT HANDLER FOR SQLWARNING SET done = 2;DECLARE CONTINUE HANDLER FOR SQLEXCEPTIONBEGINSET done = 3;ROLLBACK; #SQL异常回滚END;/* 1.输入参数妥当性检查 */IF (p_操作者 IS NULL OR p_操作者 = '') THENRETURN 9;END IF;SET done = 0;START TRANSACTION;loop_label:LOOP# 读入一条记录, 代入到各个变量中FETCH staffPaidVacationDaysCurINTO empNo, #员工号dateHire, #就职日workYears, #集团内工作年数lastYearRemainDays #昨年残日数;IF done = 1 THENLEAVE loop_label;END IF;/*根据集团内工作年限+分公司就职年限计算下一年度带薪天数*/ SET elapseYear = YEAR(current_timestamp)- Year(dateHire)+ workYears;IF elapseYear = 0 THENSET nowYearLeaveDays = 10;ELSEIF elapseYear = 1 THENSET nowYearLeaveDays = 11;ELSEIF elapseYear = 2 THENSET nowYearLeaveDays = 12;ELSEIF elapseYear = 3 THENSET nowYearLeaveDays = 14;ELSEIF elapseYear = 4 THENSET nowYearLeaveDays = 16;ELSEIF elapseYear = 5 THENSET nowYearLeaveDays = 18;ELSEIF elapseYear >= 6 THENSET nowYearLeaveDays = 20;END IF;SET done = 0;SET p_员工号= empNo;UPDATE T_PAID_VACATIONSETLAST_YEAR_REMAIN_DAYS = lastYearRemainDays,THIS_YEAR_BASE_DAYS = nowYearLeaveDays,UPDATE_DATETIME = current_timestamp,UPDATE_USER_ID = 'SYS',UPDATE_TERMINAL_ID = 'MANUAL'WHERE EMP_NO = CONVERT(empNo USING binary);IF done = 3 THENRETURN 6;END IF;END LOOP;COMMIT;END4.MySql存储过程调用时的iBatis用Mapper例BaseInfoEditMapper.xml<?xml version="1.0"encoding="UTF-8"?><!DOCTYPE mapperPUBLIC"-////DTD Mapper 3.0//EN""/dtd/ibatis-3-mapper.dtd"><mapper namespace="com.xxx.web.mapper.base_info_edit"><select id="VacationProcedure"parameterType="VacationBean"statementType="CALLABLE"> { call paid_vacation_compute (#{ReturnValue,javaType=INTEGER, jdbcType=INTEGER, mode=OUT},#{StaffNumber,javaType=String, jdbcType=CHAR, mode=INOUT},#{HireDate,javaType=String, jdbcType=VARCHAR, mode=IN},#{OperateID,javaType=String, jdbcType=VARCHAR, mode=IN})}</select></mapper>5.MySql函数调用时的iBatis用Mapper例BaseInfoEditMapper.xml<?xml version="1.0"encoding="UTF-8"?><!DOCTYPE mapperPUBLIC"-////DTD Mapper 3.0//EN""/dtd/ibatis-3-mapper.dtd"><mapper namespace="com.xxx.web.mapper.base_info_edit"><select id="VacationProcedure"parameterType="VacationBean"statementType="CALLABLE"> { #{ReturnValue,javaType=INTEGER, jdbcType=INTEGER, mode=OUT} =call paid_vacation_compute (#{StaffNumber,javaType=String, jdbcType=CHAR, mode=IN},#{HireDate,javaType=String, jdbcType=VARCHAR, mode=IN},#{OperateID,javaType=String, jdbcType=VARCHAR, mode=IN} )} </select></mapper>6.JAVA调用例1(MySql存储过程和函数相同)package com.XXX.impl;import java.util.ArrayList;import java.util.List;import com.XXX.web.bean.VacationCreateBean;import com.XXX.web.dao.BaseInfoEditDAO;import com.XXX.web.util.BasicSqlSupport;public class BaseInfoEditDAOImpl extends BasicSqlSupport implements BaseInfoEditDAO { public boolean addBaseInfo(BaseInfoEditBean objUserInfo) throws Exception {boolean blnFlag=false;//成功FLAG;//全公司员工下一年度带薪休假一发赋予处理VacationCreateBean objVacationCreateBean = new VacationCreateBean();objVacationCreateBean.setStaffNumber(objUserInfo.getSTAFF_NUMBER());objVacationCreateBean.setHireDate(objUserInfo.getDATE_HIRE().toString());objVacationCreateBean.setOperateID(objUserInfo.getCREATE_USER_ID());objVacationCreateBean.setDhcWorkYearsShinKi(objUserInfo.getDHC_WORK_YEARS());String returnValue = (String)this.session.selectOne("com.XXX.web.mapper.base_info_edit.VacationProcedure", objVacationCreateBean);//System.out.println("staffNumber=" + objVacationCreateBean.getStaffNumber());//System.out.println("result=" + objVacationCreateBean.getReturnValue());//System.out.println("returnValue=" + returnValue);//追加結果の判断blnFlag=true;return blnFlag;}}7.処理DAO接口package com.XXX.web.dao;import java.util.List;import com.XXX.web.bean.BaseInfoEditBean;/*** 员工基本信息画面の処理DAO*/public interface BaseInfoEditDAO {public List<BaseInfoEditBean> selectAuthoriyList() throws Exception;public String selectStaffId() throws Exception;public int selectOpetateTimeNum(String strStaffNumber) throws Exception;public boolean addBaseInfo(BaseInfoEditBean objUserInfo) throws Exception;public boolean updateBaseInfo(BaseInfoEditBean objUserInfo) throws Exception;public BaseInfoEditBean searchBaseInfo(String strStaffNumber) throws Exception; }8.共同処理package com.XXX.web.util;import org.apache.ibatis.session.SqlSession;public class BasicSqlSupport{protected SqlSession session;public SqlSession getSession() {return session;}public void setSession(SqlSession session) {this.session = session;} }9. DAO与MAP间的交互BEANpackage com.XXX.web.bean;import java.io.Serializable;public class VacationCreateBean implements Serializable{private int ReturnValue;private String StaffNumber;private String HireDate;private String OperateID;private int WorkYearsShinKi;public int getReturnValue() {return ReturnValue;}public void setReturnValue(int returnValue) {ReturnValue = returnValue;}public String getStaffNumber() {return StaffNumber;}public void setStaffNumber(String staffNumber) {StaffNumber = staffNumber;}public String getHireDate() {return HireDate;}public void setHireDate(String hireDate) {HireDate = hireDate;}public String getOperateID() {return OperateID;}public void setOperateID(String operateID) {OperateID = operateID;}public int getDhcWorkYearsShinKi() {return dhcWorkYearsShinKi;}public void setDhcWorkYearsShinKi(int dhcWorkYearsShinKi) {this.dhcWorkYearsShinKi = dhcWorkYearsShinKi;}}10.通过MAIN函数进行调用package com.ohc.pms.batch;import java.io.FileInputStream;import java.io.IOException;import java.sql.CallableStatement;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.Properties;import org.apache.log4j.Logger;import org.apache.log4j.PropertyConfigurator;public class VacationCreate {/**JDBC驱动名 */static String jdbcDriver = "com.mysql.jdbc.Driver";/**DB URL */static String dbURL = "jdbc:mysql://172.999.999.35:3306/empdb";/** DB用户名 */static String user = "empuser";/**DB密码 */static String pass = "empuser123";/**日志输出 */static protected Logger log = Logger.getLogger(VacationCreate.class );public static void main(String[] args) {Connection conn = null;CallableStatement stmt = null;try{PropertyConfigurator.configure(System.getProperty("user.dir") + "\\" + "log4j.properties");("実行路径:" + System.getProperty("user.dir"));String fileName = "jdbc.properties"; // 属性文件名Properties conf = new Properties();try {conf.load(new FileInputStream(System.getProperty("user.dir") + "\\" + "jdbc.properties"));} catch (IOException e) {System.err.println("Cannot open " + fileName + ".");e.printStackTrace();System.exit(-1); // 程序終了}// 读入jdbcDriver = conf.getProperty("driver");dbURL = conf.getProperty("url");user = conf.getProperty("user");pass = conf.getProperty("password");//JDBC driver登録Class.forName("com.mysql.jdbc.Driver");("DB连接。
java调用sql函数_java调用数据库中的函数和存储过程
java调用sql函数_java调用数据库中的函数和存储过程Java是一种常用的编程语言,用于开发各种类型的应用程序,包括与数据库进行交互的应用程序。
在Java程序中,我们可以使用JDBC(Java Database Connectivity)技术来连接和操作数据库。
通过JDBC,我们可以调用数据库中的函数和存储过程来执行一些特定的任务。
在Java中调用SQL函数和存储过程的基本步骤如下:2. 建立数据库连接:使用JDBC连接字符串、用户名和密码等相关参数来创建与数据库的连接。
JDBC提供了一个名为Connection的接口来表示与数据库的连接。
可以使用DriverManager类的静态方法getConnection来获取数据库连接对象。
```javaString username = "用户名";String password = "密码";Connection connection = DriverManager.getConnection(url, username, password);```3. 创建CallableStatement对象:CallableStatement是一个表示可以执行存储过程或函数的SQL语句的接口。
使用Connection对象的prepareCall方法创建一个CallableStatement对象。
```javaString sql = "{call 存储过程或函数名称(参数1, 参数2, ...)}";CallableStatement statement = connection.prepareCall(sql);```4. 设置参数:如果存储过程或函数需要输入参数,可以使用setXXX 方法设置参数的值。
XXX表示参数的数据类型,例如setInt、setString 等。
参数索引从1开始。
```javastatement.setString(1, "参数值");```5. 执行SQL语句:使用execute方法执行存储过程或函数。
TN_ORA_0001_oracle存储过程调用java程序或外部bat文件
oracle存储过程调用java程序或外部bat文件by 胡珏1.调用bat文件1.1.创建java sourcecreate or replace and compile java source named exesyscommand as import java.io.*;publicclass ExeSysCommand{publicstatic String ExeCmd(String cmd) {Process proc=null;int exitValue;try {System.out.println(cmd);proc = Runtime.getRuntime().exec(cmd);exitValue = proc.waitFor();if (exitValue == 0) {return"PASS";} else {return"FAIL";}} catch (Exception e) {return e.getMessage();}}publicstaticvoid P_ExeCmd(String cmd) {Process proc = null;int exitValue;try {System.out.println(cmd);proc = Runtime.getRuntime().exec(cmd);exitValue = proc.waitFor();} catch (Exception e) {System.out.println(e.getMessage());}//proc.destroy();//proc=null;}publicstaticvoid main(String[] args)1.2.创建函数或存储引用该java source1.3.授权1.4.定义bat文件1.5.执行2.调用java程序2.1.创建java sourcecreate or replace and compile java source named httprequest asimport java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.OutputStreamWriter;import .URL;import .URLConnection;import .URLEncoder;import java.util.List;import java.util.Map;publicclass HttpRequest {finalstatic String username = "cluster";finalstatic String password = "cluster";finalstatic String url_encode = "UTF-8";publicstaticvoid main(String[] args) {//发送 GET 请求Strings=HttpRequest.sendGet("http://192.168.117.2:8081/kettle/executeTrans/ ", "trans=D:/KETTLE/sms.ktr&content=22");System.out.println(s);//发送 POST 请求Stringsr=HttpRequest.sendPost("http://192.168.117.2:8081/kettle/executeTran s/", "trans=D:/KETTLE/sms.ktr&content=22");System.out.println(sr);}* 向指定URL发送GET方法的请求** @param url* 发送请求的URL* @param param* 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
JAVA调用存储过程
CallableStatement对象为所有的DBMS提供了一种以标准形式调用已储存过程的方法。
已储存过程储存在数据库中。
对已储存过程的调用是CallableStatement对象所含的内容。
这种调用是用一种换码语法来写的,有两种形式:一种形式带结果参,另一种形式不带结果参数。
结果参数是一种输出(OUT)参数,是已储存过程的返回值。
两种形式都可带有数量可变的输入(IN参数)、输出(OUT参数)或输入和输出(INOUT参数)的参数。
问号将用作参数的占位符。
在JDBC中调用已储存过程的语法如下所示。
注意,方括号表示其间的内容是可选项;方括号本身并非语法的组成部份。
{call过程名[(?,?,...)]}返回结果参数的过程的语法为:{?=call过程名[(?,?,...)]}不带参数的已储存过程的语法类似:{call过程名}通常,创建CallableStatement对象的人应当知道所用的DBMS是支持已储存过程的,并且知道这些过程都是些什么。
然而,如果需要检查,多种DatabaseMetaData方法都可以提供这样的信息。
例如,如果DBMS支持已储存过程的调用,则supportsStoredProcedures方法将返回true,而getProcedures方法将返回对已储存过程的描述。
CallableStatement继承Statement的方法(它们用于处理一般的SQL语句),还继承了PreparedStatement的方法(它们用于处理IN参)。
CallableStatement中定义的所有方法都用于处理OUT参数或INOUT参数的输出部分:注册OUT参数的JDBC类型(一般SQL类型)、从这些参数中检索结果,或者检查所返回的值是否为JDBC NULL。
1、创建CallableStatement对象CallableStatement对象是用Connection方法prepareCall创建的。
代码调用存储过程 java
代码调用存储过程java如何在Java中调用存储过程?在Java开发中,有时候需要调用数据库中已经定义好的存储过程来执行特定的操作。
存储过程是一组预定义的SQL语句集合,它们经过编译,存储在数据库中并可以多次重复调用。
本文将详细介绍如何在Java中调用存储过程,并给出逐步的代码示例。
步骤一:建立数据库连接首先,我们需要建立与数据库的连接。
在Java中,可以使用JDBC(Java Database Connectivity)技术来实现与数据库的连接。
JDBC是Java提供的一个标准API,用于与各种关系型数据库进行交互。
在调用存储过程之前,需要先加载数据库驱动和建立数据库连接。
下面的代码展示了如何加载MySQL数据库驱动并建立与数据库的连接:import java.sql.*;public class CallStoredProcedure {public static void main(String[] args) {Connection conn = null;Statement stmt = null;try{Class.forName("com.mysql.jdbc.Driver");conn =DriverManager.getConnection("jdbc:mysql:localhost/testdb", "username", "password");}catch(SQLException se){se.printStackTrace();}catch(Exception e){e.printStackTrace();}}}其中,"com.mysql.jdbc.Driver"是MySQL数据库的驱动类名,"jdbc:mysql:localhost/testdb"是数据库连接的URL,"username"和"password"分别是数据库的用户名和密码。
java sqlserver中存储过程return返回值处理
java sqlserver中存储过程return返回值处理Java与SQL Server中存储过程的返回值处理一、介绍存储过程是一组预先编译的SQL语句集合,可以被视为一种数据库对象,用于执行一系列数据库操作。
在Java应用程序中与SQL Server数据库交互时,经常需要调用存储过程并处理其返回值。
本文将详细介绍在Java中如何调用SQL Server存储过程,并处理其返回值。
我们将按照以下步骤逐一分析。
二、创建存储过程首先,我们需要在SQL Server数据库中创建一个存储过程,用于演示和测试。
假设我们创建一个简单的存储过程,用于根据输入参数获取员工的姓名。
CREATE PROCEDURE GetEmployeeName@EmployeeID INT,@EmployeeName VARCHAR(100) OUTPUTASBEGINSELECT @EmployeeName = EmployeeNameFROM EmployeeWHERE EmployeeID = @EmployeeIDEND这个存储过程接受一个输入参数@EmployeeID,以及一个输出参数@EmployeeName。
它根据输入的员工ID查询数据库,将结果赋值给输出参数@EmployeeName。
三、Java代码中调用存储过程现在,我们可以在Java代码中调用SQL Server中的存储过程。
首先,我们需要建立与数据库的连接。
1. 导入相关的包和类import java.sql.*;2. 建立数据库连接String connectionString ="jdbc:sqlserver:localhost:1433;databaseName=YourDatabase;user=Your User;password=YourPassword";Connection connection =DriverManager.getConnection(connectionString);在上面的代码中,我们使用了JDBC驱动程序建立与数据库的连接。
银行存储系统java课程设计 概述及解释说明
银行存储系统java课程设计概述及解释说明1. 引言1.1 概述银行存储系统是一种用于管理银行存储业务的软件系统。
它通过提供一系列功能来帮助银行进行客户账户管理、资金流动追踪、交易处理等操作。
本篇文章旨在介绍一个基于Java开发的银行存储系统的课程设计,并详细解释说明该系统的设计思路、数据结构与算法选择、技术实现和模块分工等。
1.2 文章结构本文将按照以下结构进行叙述:- 第二部分:银行存储系统概述,介绍该系统的功能、设计要求以及背后的技术背景。
- 第三部分:Java课程设计解释说明,阐述该课程设计所采用的设计思路、数据结构与算法选择以及系统实现和模块分工等。
- 第四部分:实现过程与技术细节,描述开发环境与工具选择、数据库设计与集成以及用户界面设计和交互流程等方面。
- 第五部分:常见问题与解决方案,针对数据安全性、性能优化和用户友好界面等方面进行常见问题的探讨。
1.3 目的本文的主要目的是介绍基于Java开发的银行存储系统课程设计,向读者展示该系统在解决实际问题时所采用的设计方法和技术手段。
同时,通过对系统实现过程和技术细节的详细描述,帮助读者理解银行存储系统开发的基本原理和方法,并为他们建立起对软件开发过程中常见问题的解决方案。
以上是“1. 引言”部分的内容介绍,旨在为读者提供明确的概述、文章结构以及切题目的目标。
接下来将进入第二部分,即“银行存储系统概述”,详细介绍该系统的功能、设计要求和技术背景。
2. 银行存储系统概述:2.1 系统功能:银行存储系统是一种基于Java开发的应用程序,旨在帮助银行及其客户有效地管理存款和账户信息。
该系统具备以下主要功能:- 账户管理:允许用户创建、关闭和管理银行账户,包括储蓄账户、支票账户等。
- 存款与提款:用户可以向自己的账户存入资金或从中进行提款操作。
- 转账服务:用户可通过该系统实现不同账户之间的转移资金操作,如转账给他人或其他自己拥有的账户。
- 查询与报表生成:提供余额查询、交易记录查询等功能,支持生成个人和整体的财务报表。
Oracle中基于Java的存储过程开发
员 除 了 可使 用 P / QI还 可 以 使 月 aa来 开 发 他 们 的业 LS j v J
务逻 辑 , 将 这 个 业 务 逻 辑 作 为 存 储 过 程 、 数 和 触 发 程 并 函
快 。任 何 一 个 设 计 良好 的 数 据库 应 用 程 序 都应 该 用 到 存储 过 程 。 存储 过 程 可 以使 得 对 数 据 库 的 管 理 、 示 关 于数 显
据 库及 其 用 户 信 息 的工 作 容 易很 多 。文 中详 细 分 析 了 J v 存 储 过 程 的 开发 步骤 。 aa
f
( ) 载 Jv 3装 a a代码 及 类 到 Or ce i al9 数据 库 中
储过 程 类 型是 : 储 过 程 、 储 函数 、 据 库 触 发 器 和 对 象 存 存 数
类 型方 法 。
1 4 存 储 过 程 的 调 用 .
在 编 写 了 Jv a a源 代码 之 后 , 下来 应 该将 J v 代 码 及 接 aa 相 应 的 J v 类 装 载 到 O al9 数据 库 中 。如 图 1 示 : aa rc i e 所 装 载 Jv 代 码 及 类 到 R B aa D MS有 以 下两 种 方 法 : 使 用 la j a 具 , 过 该 工 具 可 以快 速 装 载 J v od v 工 a 通 a a源 代 码 (jv ) J v 二 进 制 代 码 ( c s ) . a 、a a a . l s 以及 J v a a a打 包 文 件
流、 逻辑 以及 对 数据 库 的 查 询 。在 Orce i中应 用 开发 人rc 9 数 据库 中 、 成 调 用说 明和 调 aa al i e 生
java存储文件的方法
java存储文件的方法在Java中,可以使用以下方法来存储文件:1. 使用FileOutputStream类:通过创建一个FileOutputStream对象,并传入文件的路径作为参数,然后使用write()方法将数据写入文件。
```javaString filePath = "path/to/file.txt";String content = "Hello, world!";try {FileOutputStream fos = new FileOutputStream(filePath);fos.write(content.getBytes());fos.close();} catch (IOException e) {e.printStackTrace();}```2. 使用BufferedWriter类:通过创建一个BufferedWriter对象,并传入一个FileWriter对象作为参数,在BufferedWriter中调用write()方法来写入文件。
```javaString filePath = "path/to/file.txt";String content = "Hello, world!";try {BufferedWriter writer = new BufferedWriter(newFileWriter(filePath));writer.write(content);writer.close();} catch (IOException e) {e.printStackTrace();}```3. 使用Files类:通过调用Files类的write()方法来写入文件。
```javaString filePath = "path/to/file.txt";String content = "Hello, world!";try {Files.write(Paths.get(filePath), content.getBytes());} catch (IOException e) {e.printStackTrace();}```这些方法都可以用来将数据写入文件,你可以根据自己的需求选择适合的方法。
使用Java编写Oracle存储过程
通常我们都使用Ps/SQL为Oracle编写存储过程,从Oracle 8开始我们可以有另一种选择:Java。
8.0开始,Oracle自带一个JVM,内置对Java的支持,任何Java能做的事情你都可以放到Oracle里面来做,你甚至可以在里面操作db2。
这让Oracle具备了极其巨大的扩展能力,只要你愿意,完全可以开发一个trigger,让它在适当的时候给管理员的msn 发送一条即时消息。
好消息说完了,现在是坏消息:由于ps/SQL是过程化的语言,它基本上不具备多态的概念,供Oracle使用的Java 方法必须申明为static,所以在Oracle中你无法使用Java的动态特性,比如接口、反射等。
不过这并不妨碍你用Java做爱做的事。
我们以一个简单的hello world为例,我想任何一个有经验的Java程序员都能够通过这个例子,派生出其他希奇古怪的应用。
首先是创建一个Java类,你可以用Jbuilder/Eclipse来编写,也可以直接在Oracle的控制台里面创建。
前者不多说,看看后一种方式。
启动SQL plus,执行如下命令:Java程序已创建。
然后在Oracle中把这个类导入成为一个函数,执行命令:函数已创建现在可以调用该函数,执行:select hello('bromon') from dual;返回结果:你好,bromon有一个需要注意的问题是,假如我们的java方法是没有参数的,比如:那么在创建函数的时候,函数名不应该有扩号:hello_sp,否则会报告函数有编译错误。
如果你的Java类是在IDE里面编写的,那么只需要在oracle中加载编译过的class文件即可,方法是:启动enterprise manage console,在“方案”下找到“源类型”,右击”Java类”,选择”加载Java“,选择对应的class文件即可。
java调用存储过程返回map组装List(含SqlServer存储过程)
Action层public ActionForward getProjectPayMoneyJsonByPayType(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response)throws Exception {JiLiangZhiFuService jiLiangZhiFuService = this.getServiceLocator().getJiLiangZhiFuService();int year = Integer.parseInt(request.getParameter("year"));String data = jiLiangZhiFuService.getProjectPayMoneyJsonByPayType(year);response.setContentType("text/xml");response.getWriter().write(data);response.getWriter().flush();response.getWriter().close();return null;}Service层public String getProjectPayMoneyJsonByPayType(int year){double allTotal = 0;Map map = jiLiangZhiFuDao.getProjectPayMoneyByPayType(year);List<DataItem> dataItemList = SessionBean.getServiceLocator().getDataItemService().getAllDataItemByTypeId("payType");Map map_ep = new HashMap();map_ep.put("account_id", 2);map_ep.put("isSelectTwoStageProject", true);List<EngineeringPhase> engineeringPhaseList =SessionBean.getServiceLocator().getEngineeringPhaseService().getEngineeringPhaseList(map_ep).getData();Map map_type = new HashMap();StringBuilder sb = new StringBuilder();sb.append("<date><total>"+engineeringPhaseList.size()+"</total>");for(EngineeringPhase engineeringPhase:engineeringPhaseList){String ep_id = engineeringPhase.getEp_id();sb.append("<ProjectPayMoneyInfo>");sb.append("<ep_id>"+ep_id+"</ep_id>");sb.append("<ep_name>"+engineeringPhase.getEp_name()+"</ep_name>");for(DataItem dataItem:dataItemList){String di_id = dataItem.getId();String r_key = ep_id + "," + di_id;if(map.containsKey(r_key)){map_type.put(di_id, map_type.containsKey(di_id) ? (Double.parseDouble(map_type.get(di_id).toString()) + Double.parseDouble(map.get(r_key).toString())) : Double.parseDouble(map.get(r_key).toString()));sb.append("<"+di_id+">"+map.get(r_key)+"</"+di_id+">");}}//项目支付金额合计sb.append("<projectTotal>"+map.get(engineeringPhase.getEp_id())+"</projectTotal>");allTotal += Double.parseDouble(map.get(engineeringPhase.getEp_id()).toString());sb.append("</ProjectPayMoneyInfo>");}//某支付类别金额合计sb.append("<ProjectPayMoneyInfo>");sb.append("<ep_id></ep_id>");sb.append("<ep_name>合计</ep_name>");DecimalFormat df = new DecimalFormat("#.00");for(DataItem dataItem:dataItemList){sb.append("<"+dataItem.getId()+">"+String.format("%.2f", map_type.get(dataItem.getId()))+"</"+dataItem.getId()+">");}//各项目累计合计sb.append("<projectTotal>"+String.format("%.2f", allTotal)+"</projectTotal>");sb.append("</ProjectPayMoneyInfo>");sb.append("</date>");return sb.toString();}Dao层public Map getProjectPayMoneyByPayType(final int year) {try {return (Map)this.getHibernateTemplate().execute(new HibernateCallback(){public Object doInHibernate(Session session) throws HibernateException, SQLException {Connection con = session.connection();Statement stmt = con.createStatement();CallableStatement cs = con.prepareCall("{call proc_records(?)}");cs.setInt(1, year);//ResultSet rs = stmt.executeQuery("{call proc_records}");ResultSet rs = cs.executeQuery();Map map = new HashMap();while (rs.next()) {map.put(rs.getString(1), rs.getString(2));}rs.close();stmt.close();return map;}});} catch ( org.springframework.dao.DataAccessException e) {throw new DataAccessException(e.getMessage(),e);}}Sql:create procedure proc_records@year intasDECLARE@map_table table(r_key varchar(100),r_value varchar(50)) DECLARE@type_id varchar(40)DECLARE@type_name varchar(50)DECLARE@project_id varchar(40)DECLARE@project_name varchar(50)DECLARE@payTypeMoney numeric(16, 2)DECLARE@sumPayTypeMoney numeric(16, 2)BEGINset@payTypeMoney= 0set@sumPayTypeMoney= 0--查询项目列表DECLARE project_cursor CURSOR for select ep_id,ep_name from AB_engineeringPhase where account_id='2'open project_cursorfetch next from project_cursor into@project_id,@project_namewhile@@FETCH_STATUS= 0begin--查询项目支付类别DECLARE projectType_cursor CURSOR for select id,name from T_DataItem where typeId='payType'order by sort ascopen projectType_cursorfetch next from projectType_cursor into@type_id,@type_namewhile@@FETCH_STATUS= 0begin--业务逻辑处理处理内层游标--获取一个项目某一项支付类型的数据--查询一个项目某一支付类别金额select@payTypeMoney=sum(checkProjectPayMoney)from JiLiangZhiFu where projectId=@project_id and payType=@type_id and enterDate>CAST(@year as varchar(4))and enterDate<CAST(@year+1 as varchar(4))and type='outer' group by payType--一个项目某一支付类别金额存入insert into@map_table values(@project_id+','+@type_id,@payTypeMoney)--一个项目累计支付类别金额set@sumPayTypeMoney=@sumPayTypeMoney+@payTypeMoney--一个项目某一支付类别金额重置为set@payTypeMoney= 0fetch next from projectType_cursor into@type_id,@type_name--内层游标向下移动一行end--插入某一项目各个支付类别的金额合计insert into@map_table values(@project_id,@sumPayTypeMoney)set@sumPayTypeMoney= 0close projectType_cursordeallocate projectType_cursorfetch next from project_cursor into@project_id,@project_name--内层游标处理结束后,外层游标才继续向下移动一行endclose project_cursordeallocate project_cursorselect*from@map_tableEND。
Java调用SQLServer的存储过程详解
Java调用SQLServer的存储过程详解Java调用SQL Server的存储过程是一种常见的数据库操作方式,本文将详细介绍Java调用SQL Server存储过程的步骤和注意事项。
主要包括如下内容:存储过程简介、Java调用存储过程的方法、事务管理、参数传递、数据操作和错误处理等方面。
一、存储过程简介存储过程是SQL Server中一组预先编译的SQL语句集合,它们被命名并存储在数据库中,可以被多次调用。
存储过程可以接受参数,可以返回结果集。
二、Java调用存储过程的方法1. 使用CallableStatement对象调用存储过程。
2. 使用JdbcTemplate的execute(方法调用存储过程。
三、事务管理四、参数传递存储过程通常需要传递参数,Java调用存储过程时需要注意以下几点:1. 设置参数的类型和值:使用CallableStatement对象的setXXX(方法,其中XXX为参数类型,如setInt(、setString(等。
2. 注册输出参数:将输出参数的位置和类型进行注册,使用CallableStatement对象的registerOutParameter(方法。
3. 获取输出参数的值:使用CallableStatement对象的getXXX(方法,其中XXX为参数类型,如getInt(、getString(等。
五、数据操作在Java调用存储过程时,可以执行各种数据库操作,如插入数据、更新数据等。
通过设置SQL语句和调用executeUpdate(或executeQuery(方法来实现。
六、错误处理在Java调用存储过程时,需要进行错误处理。
可以通过捕获SQL异常并输出错误信息来实现。
使用try-catch块来捕获异常,然后使用SQLException对象获取具体的错误信息。
总结:本文详细介绍了Java调用SQL Server存储过程的步骤和注意事项。
主要包括存储过程简介、Java调用存储过程的方法、事务管理、参数传递、数据操作和错误处理等方面。
java存储过程写法
java存储过程写法在Java中,可以通过JDBC(Java Database Connectivity)来调用和执行存储过程。
下面我将从多个角度来介绍Java中存储过程的写法。
1. 使用CallableStatement:在Java中,可以使用CallableStatement来调用存储过程。
首先,你需要获取数据库连接,然后创建一个CallableStatement对象,并设置存储过程的参数,最后执行存储过程。
例如:java.Connection conn = DriverManager.getConnection(url, username, password);CallableStatement cs = conn.prepareCall("{callyour_stored_procedure(?, ?)}");cs.setInt(1, parameter1);cs.setString(2, parameter2);cs.execute();2. 使用存储过程注解:一些持久层框架(如MyBatis)提供了注解的方式来调用存储过程。
你可以在Java方法上使用注解来指定要调用的存储过程的名称和参数。
例如(使用MyBatis的@Select注解):java.@Select("{call your_stored_procedure(#{parameter1, mode=IN, jdbcType=INTEGER}, #{parameter2, mode=IN, jdbcType=VARCHAR})}")。
void callStoredProcedure(int parameter1, Stringparameter2);3. 使用存储过程的ORM映射:一些ORM框架(如Hibernate)允许你将存储过程映射为Java方法,然后直接调用这些方法来执行存储过程。
oracle存储过程调用javasource的方法(一)
oracle存储过程调用javasource的方法(一)Oracle存储过程调用JavaSource的方法引言在Oracle数据库中,我们可以使用存储过程来进行复杂的数据处理和业务逻辑实现。
有时候,我们需要在存储过程中调用Java代码,以实现更复杂的功能。
本文将介绍一些在Oracle存储过程中调用JavaSource的方法。
方法一:使用CREATE JAVA语句创建Java类首先,我们可以使用CREATE JAVA语句在Oracle数据库中创建一个Java类,然后在存储过程中调用这个Java类的方法。
具体步骤如下: 1. 使用CREATE JAVA语句在Oracle数据库中创建一个Java类。
例如:CREATE OR REPLACE AND COMPILE JAVA SOURCE NAMED "He lloWorld" ASpublic class HelloWorld {public static String sayHello(String name) {return "Hello, " + name + "!";}};2.创建一个存储过程,其中调用了刚刚创建的Java类的方法。
例如:CREATE OR REPLACE PROCEDURE callJavaMethod ISlanguage Java name '() return ';resultStr ;BEGINresultStr := ('World');DBMS__line(resultStr);END;3.执行存储过程,测试Java类的调用是否成功。
例如:BEGINcallJavaMethod;END;方法二:使用CREATE LIBRARY语句创建Java库另一种方式是使用CREATE LIBRARY语句在Oracle数据库中创建一个Java库,然后在存储过程中调用这个Java库。
java保存数组到数据库的方法
在Java编程中,我们经常需要将数组中的数据保存到数据库中。
这篇文章将介绍一些常见的方法和技巧,来帮助你在Java中实现这一功能。
一、使用JDBC保存数组数据到数据库1. JDBC(Java Database Connectivity)是Java用于与数据库进行连接和操作的一套API。
我们可以使用JDBC来将数组中的数据保存到数据库中。
2. 我们需要在Java程序中引入JDBC相关的包,然后通过JDBC连接数据库、创建SQL语句,并执行插入操作。
3. 对于数组,我们通常需要使用循环来逐个将数组中的数据插入到数据库中。
这里需要注意的是,不同的数据库可能对于插入数据的方式有一些差异,需要根据具体的数据库类型来编写相应的SQL语句。
4. 在使用JDBC操作数据库的过程中,我们需要注意异常处理和资源释放,以确保程序的稳定性和性能。
二、使用ORM框架保存数组数据到数据库1. 除了直接使用JDBC操作数据库外,我们还可以通过ORM (Object-Relational Mapping)框架来简化数据库操作。
ORM框架可以将Java对象与数据库表进行映射,从而实现对象的持久化。
2. 使用ORM框架保存数组数据到数据库,通常需要首先定义好对应的实体类,并在实体类中设置数组属性。
3. 我们需要配置ORM框架的映射规则,以及数据库连接等相关信息。
4. 我们可以通过ORM框架提供的API来操作数据库,将数组中的数据保存到数据库中。
ORM框架会帮助我们生成对应的SQL语句,并执行数据库操作。
5. 在使用ORM框架时,我们需要注意配置文件的编写、映射关系的设置以及性能优化等方面。
三、使用Spring Data JPA保存数组数据到数据库1. Spring Data JPA是Spring框架中的一个子项目,它提供了一种简化数据库访问的方式。
通过Spring Data JPA,我们可以很方便地将数组数据保存到数据库中。
2. 我们需要在Spring项目中引入Spring Data JPA相关的依赖,然后配置好数据源和实体类。
java中将数据读取到内存中的方法
在Java中,将数据读取到内存中是一个常见且重要的操作,涉及到了文件操作、数据结构和内存管理等方面。
本文将从简单到复杂,由浅入深地探讨Java中将数据读取到内存中的方法,帮助读者更深入地理解这一主题。
1. 使用FileInputStream和BufferedInputStream读取文件数据在Java中,最基本的将数据读取到内存中的方法是使用FileInputStream和BufferedInputStream。
通过FileInputStream 可以打开一个文件输入流,然后再利用BufferedInputStream来读取文件数据并且缓存,加快读取速度,降低IO负担。
这种方法适用于小型文件的读取,但对于大型文件,性能可能不够理想。
2. 使用RandomAccessFile进行随机读取如果需要随机读取文件中的数据,可以使用Java中的RandomAccessFile类。
它可以对文件进行读写操作,并且支持随机访问文件的任意位置。
这种方法对于需要在文件中查找特定数据记录或进行部分数据处理的场景非常适用,但需要注意文件指针的位置管理。
3. 使用Java NIO进行文件读取Java NIO(New IO)提供了对文件和网络数据的高效处理,其中的FileChannel可以实现高效的文件读取。
通过使用ByteBuffer和FileChannel进行数据读取和写入,能够更好地利用内存缓冲区和操作系统的IO机制,提升读取性能。
NIO还提供了直接内存访问的方式,可以避免数据在Java堆和本地内存之间的复制,提高了大规模数据读取的效率。
4. 使用MemoryMappedFile进行内存映射Java提供了MemoryMappedFile机制,将文件直接映射到内存中,可以直接在内存中对文件进行操作。
这种方式省去了IO操作,提高了数据读取的速度,并且能够充分利用操作系统的文件缓存。
但由于文件映射到内存中,需要注意内存占用和映射文件大小的限制。
procedure create_tables already exists -回复
procedure create_tables already exists -回复“[procedure create_tables already exists]”是数据库中一个已存在的存储过程。
在本文中,我将详细解释什么是存储过程,以及为什么在数据库中创建和使用存储过程是重要的。
我还将提供关于如何创建和使用存储过程的详细步骤,以帮助读者更好地理解和应用这一概念。
存储过程是一组在数据库中预定义的SQL 语句的集合,可以被封装和重复使用。
它类似于一种脚本或程序,可以按照特定的逻辑来执行数据库操作。
存储过程通常用于实现复杂的业务逻辑、数据操作和数据校验。
使用存储过程的好处包括提高数据库性能、减少代码重复、提高数据安全性和简化应用开发流程。
现在让我们来一步一步了解如何在数据库中创建和使用存储过程。
第一步是创建存储过程。
要创建存储过程,你需要具有适当的数据库权限。
一般来说,在数据库管理系统(DBMS)中使用CREATE PROCEDURE 语句可以创建存储过程。
下面是一个示例如何创建名为"create_tables" 的存储过程。
sqlCREATE PROCEDURE create_tablesASBEGIN在这里写入创建表的SQL 语句END在存储过程的BEGIN 和END 关键字之间,你可以编写执行特定任务的SQL 语句。
在这个示例中,我们将在存储过程中创建表,但你可以根据自己的需求添加其他的SQL 语句。
第二步是保存存储过程。
一旦你编写完存储过程的代码,你需要将其保存到数据库中。
在大多数DBMS 中,使用SAVE 或者SAVE AS 命令可以完成保存。
例如,使用以下命令将存储过程保存在名为"my_database" 的数据库中:sqlSAVE PROCEDURE create_tables请注意,保存的过程可能因DBMS 的不同而有所差异,所以最好参考相应的文档或使用DBMS 提供的图形用户界面来完成保存。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Oracle8i中使用Java语言来开发存储过程本篇文章来源与时代朝阳数据库(原晓通数据库)培训部Oracle 资料库。
在Oracle8i之前,开发人员只能使用PL/SQL来开发存储过程。
而在Oracle8i 之中,不仅可以使用原有的PL/SQL开发存储过程,而且也可以使用Java语言来开发存储过程。
本篇文章将简单介绍关于这方面的知识,包括以下内容:●存储过程简介;●Java存储过程●Java存储过程的开发步骤●使用Java开发过程;●使用Java开发函数;●使用Java开发包;●使用Java开发触发器;●使用Java开发对象方法;●使用JDeveloper开发JSP。
存储过程简介存储过程是存储在数据库中的一段存储程序。
当创建存储过程时,系统会对其进行编译,并将执行代码存储到数据库中。
1.设计存储过程的方针●在定义存储过程时,要使用其完成单一、相对集中的任务。
●在定义存储过程时,不要定义已经由其它特征所提供功能的过程。
例如,不要定义强制数据完整性的过程(使用完整性约束)。
2.存储过程的优点1)安全性当创建了存储过程之后,可以将执行该过程的权限授予其它用户,从而使得他可以执行特定的数据库操作,而不能访问其它模式对象(例如表)。
例如,你可以将执行过程(更新表)的权限授予其它用户,但不授予它们直接访问该表的权限。
2)性能●存储过程只被发送到数据库一次,相对于SQL语句或PL/SQL块而言,其网络通信量更小。
●当调用存储过程时,数据库会直接运行该存储过程,无需进行编译。
相对于SQL语句或PL/SQL块而言,其执行速度更快。
3)内存分配存储过程充分利用了Oracle共享内存的能力。
在将存储过程装载到内存中后,多个用户可以同时调用该存储过程,从而降低了应用对Oracle的实际内存需求。
4)生产力存储过程提高了开发生产力。
通过将公共集合编写为存储过程,避免了冗余代码,从而提高了开发生产力。
例如,我们可以编写用于插入、更新、删除AUTHS表的过程,此后应用可以直接调用这些过程,而无需重写SQL语句。
当管理数据的方法发生变化时,只需要修改过程,而不需要对应用进行任何修改。
Java存储过程在以前的Oracle版本中,开发存储过程是通过PL/SQL来完成的。
而在Oracle8i 版本中,我们不仅可以使用PL/SQL开发存储过程,而且还可以使用Java语言来开发存储过程。
1.PL/SQL与Java存储过程比较与PL/SQL相比,使用Java语言开发存储过程有以下优点:●Java语言具有更强大的运算能力,提供了更多的运算方法。
当要完成进行复杂运算的存储过程时,使用JSP将是你最好的选择。
●PL/SQL只能用于Oracle数据库,而Java语言可以应用于更多的数据库系统(如Sybase、DB2、Informix等等),所以Java存储过程将具有更好的兼容性、可移植性。
2.JSP分类Java存储过程包括过程、函数、触发器以及对象方法四种类型。
3.调用JSP的四种方法●CALL语法;●DML语句;●PL/SQL块、子程序、包;●由触发器隐含调用。
Java存储过程的开发步骤1.编写Java源代码当开发Java存储过程时,首先应该编写Java源代码。
如下图所示:注意事项:●当以public方式声明类时,类名必须与其文件名完全一致。
●只有public static方法可以作为Java存储过程。
2.装载Java代码及类到Oracle8i数据库中在编写了Java源代码之后,接下来应该将Java代码及相应的Java类装载到Oracle8i数据库中。
如下图所示:装载Java代码及类到RDBMS有以下两种方法:●使用loadjava工具,通过该工具可以快速装载Java源代码(.java)、Java二进制代码(.class)以及Java打包文件(.jar)。
●使用CREATE Java、ALTER Java装载Java代码。
其中,前一种方法相对简单,并且我们推荐你使用这种方法。
3.生成调用说明在装载了Java类之后,接下来应该生成对public static方法的调用说明,最终完成Java存储过程的开发工作。
如下图所示:完成上述步骤之后,就完成了Java存储过程的开发工作,然后就可以调用并执行该Java存储过程了。
使用Java开发过程过程用于执行某种操作。
需要注意的是,过程所对应的Java方法返回值必须为空(void)。
本节以创建用于插入、修改和删除AUTHS表的JSP为例,说明使用Java开发过程的方法。
如下图所示:下面讲述完成上述任务的方法及过程:1.编写Java源代码程序清单如下(manipulate_auths.java):/* 导入Java类 */import java.sql.*;import java.io.*;import oracle.jdbc.driver.*;/* 主类 */public class manipulate_auths {public static void insert_auths(String code,String name,int sex,String birthdate,String entry_date_time)throws SQLException {/* 建立到数据库的缺省连接 */Connection conn = new OracleDriver().defaultConnection();/* 构造动态SQL语句 */String sql = "INSERT INTO auths(author_code,name,sex,birthdate,entry_date_time) "+"VALUES (?,?,?,?,?)";/* 使用try ... catch语句抓取并抛出例外 */try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql);/* 设置动态SQL参数值 */pstmt.setString(1, code);pstmt.setString(2, name);pstmt.setInt(3, sex);pstmt.setString(4, birthdate);pstmt.setString(5, entry_date_time);/* 执行动态SQL语句 */pstmt.executeUpdate();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) { }}public static void delete_auths (String code)throws SQLException {/* 建立到数据库的缺省连接 */Connection conn = new OracleDriver().defaultConnection(); /* 构造动态SQL语句 */String sql = "DELETE FROM auths WHERE author_code = ?"; /* 使用try ... catch语句抓取并抛出例外 */try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql); /* 设置动态SQL参数值 */pstmt.setString(1, code);/* 执行动态SQL语句 */pstmt.executeUpdate();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) { }}public static void modify_salary (String code,float salary) throws SQLException {/* 建立到数据库的缺省连接 */Connection conn = new OracleDriver().defaultConnection();/* 构造动态SQL语句 */String sql = "UPDATE auths SET salary = ? WHERE author_code = ?";/* 使用try ... catch语句抓取并抛出例外 */try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql);/* 设置动态SQL参数值 */pstmt.setFloat(1, salary);pstmt.setString(2, code);/* 执行动态SQL语句 */pstmt.executeUpdate();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) { }}}2.装载Java代码及类到Oracle8i数据库中在编写了Java源代码之后,就可以将Java对象装载到Oracle8i数据库中了。
下面是完成这项任务的方法:3.发行Java,生成调用说明在装载了Java类后,就可以发行该Java类,并生成调用其方法的过程说明了。
下面是完成该项任务的方法:4.调用JSP在生成了调用Java方法的过程说明之后,我们就可以调用JSP了。
例如:使用Java开发函数函数用于返回特定数据。
本节将通过创建用于返回作者的文章标题,以及某种类型的文章个数为例,说明使用Java开发函数的方法。
如下图所示:下面讲述完成上述任务的方法和过程。
1.编写Java源代码程序清单如下(query_article.java):/* 导入Java类 */import java.sql.*;import java.io.*;import oracle.jdbc.driver.*;/* 主类 */public class query_article {public static String auths_article(String code)throws SQLException {/* 建立到数据库的缺省连接 */Connection conn = new OracleDriver().defaultConnection();/* 构造动态SQL语句 */String sql1 = "SELECT name FROM auths WHERE author_code=?";String sql2 = "SELECT title FROM article WHERE author_code=?";/* 声明并初始化auths_article变量 */String auths_article = new String();/* 使用try ... catch语句抓取并抛出例外 */try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql1);/* 设置动态SQL参数值 */pstmt.setString(1, code);/* 执行查询,并将结果保存到结果集中 */ResultSet rset = pstmt.executeQuery();/* 循环获取并处理结果集数据 */while(rset.next())auths_article =auths_article + rset.getString(1);/* 关闭结果集 */rset.close();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) {}auths_article = auths_article + "所编写文章的标题如下:\n";try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql2);/* 设置动态SQL参数值 */pstmt.setString(1, code);/* 执行查询,并将结果保存到结果集中 */ResultSet rset = pstmt.executeQuery();/* 循环获取并处理结果集数据 */while(rset.next()) {auths_article =auths_article + " " + rset.getString(1) + "\n";}/* 关闭结果集 */rset.close();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) {}return auths_article;}public static String query_type_article_number(String code)throws SQLException {/* 建立到数据库的缺省连接 */Connection conn = new OracleDriver().defaultConnection();/* 构造动态SQL语句 */String sql = "SELECT count(*) FROM article WHERE article_code IN "+ "(SELECT article_code FROM article_type WHEREtype_code=?)";String article_number = new String("类型为" + code + "的文章共有 ");/* 使用try ... catch语句抓取并抛出例外 */try {/* 准备动态SQL语句 */PreparedStatement pstmt = conn.prepareStatement(sql);/* 设置动态SQL参数值 */pstmt.setString(1, code);/* 执行查询,并将结果保存到结果集中 */ResultSet rset = pstmt.executeQuery();/* 循环获取并处理结果集数据 */while(rset.next())article_number = article_number + rset.getString(1) + "篇";/* 关闭结果集 */rset.close();/* 关闭动态SQL语句 */pstmt.close();} catch (SQLException e) {}return article_number;}}2.装载Java代码及类到Oracle8i数据库中在编写了Java源代码之后,就可以将Java对象装载到Oracle8i数据库中了。