手册目录

概述

YMP在线手册

浏览12651
更新时间2022-04-11

针对于存储过程,JDBC模块提供了IProcedureOperator操作器接口及其默认接口实现类DefaultProcedureOperator来帮助你完成,存储过程有以下几种调用方式,举例说明:

  • 有输入参数无输出参数:

    IConnectionHolder _conn = JDBC.get().getDefaultConnectionHolder();
    try {
        // 执行名称为`procedure_name`的存储过程,并向该存储过程转入两个字符串参数
        IProcedureOperator<Object[]> _opt = new DefaultProcedureOperator<Object[]>("procedure_name", _conn)
                .addParameter("param1")
                .addParameter("param2")
                .execute(IResultSetHandler.ARRAY);
        // 遍历结果集集合
        for (List<Object[]> _item : _opt.getResultSets()) {
            ResultSetHelper.bind(_item).forEach(new ResultSetHelper.ItemHandler() {
                public boolean handle(ResultSetHelper.ItemWrapper wrapper, int row) throws Exception {
                    System.out.println(wrapper.toObject(new ArchiveVObject()).toJSON());
                    return true;
                }
            });
        }
    } finally {
        _conn.release();
    }
  • 有输入输出参数:

    IConnectionHolder _conn = JDBC.get().getDefaultConnectionHolder();
    try {
        // 通过addOutParameter方法按存储过程输出参数顺序指定JDBC参数类型
        new DefaultProcedureOperator("procedure_name", _conn)
                .addParameter("param1")
                .addParameter("param2")
                .addOutParameter(Types.VARCHAR)
                .execute(new IProcedureOperator.IOutResultProcessor() {
                    public void process(int idx, int paramType, Object result) throws Exception {
                        System.out.println(result);
                    }
                });
    } finally {
        _conn.release();
    }
  • 另一种写法:

    JDBC.get().openSession(new ISessionExecutor<List<List<Object[]>>>() {
        public List<List<Object[]>> execute(ISession session) throws Exception {
            // 创建存储过程操作器对象
            IProcedureOperator<Object[]> _opt = new DefaultProcedureOperator<Object[]>("procedure_name", session.getConnectionHolder())
                    .addParameter("param1")
                    .addParameter("param2")
                    .addOutParameter(Types.VARCHAR)
                    .addOutParameter(Types.INTEGER)
                    .setOutResultProcessor(new IProcedureOperator.IOutResultProcessor() {
                        public void process(int idx, int paramType, Object result) throws Exception {
                            System.out.println(result);
                        }
                    }).setResultSetHandler(IResultSetHandler.ARRAY);
            // 执行
            _opt.execute();
            return _opt.getResultSets();
        }
    });

相关视频

更多

免费

php8,我来也
初级php8,我来也

322010次学习

收藏

免费

Thinkphp6.0正式版视频教程
中级Thinkphp6.0正式版视频教程

382625次学习

收藏

免费

细说PHP第一季
中级细说PHP第一季

283371次学习

收藏

免费

简单聊聊PHP创业那点事
初级简单聊聊PHP创业那点事

13425次学习

收藏

精品课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时 | 62.5万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时 | 39.8万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时 | 73.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号