蓝布编程网

分享编程技术文章,编程语言教程与实战经验

如何在线把数据库的存储过程,快速发布成标准API接口?

存储过程配置和管理

登录管理后台,


进入【存储过程管理】界面,

支持的数据库

  • MySQL
  • Sql Server

添加存储过程配置

管理后台 > 数据库管理 > 存储过程管理 > 添加

注意:表单中存储过程名称必须与存储过程定义内容里的名称保持一致

  • 保存配置:仅保存存储过程的配置信息,比如开关、备注等
  • 保存并运行:保存存储过程的配置信息+执行存储过程定义的内容(如果强制覆盖,会先删除原有的存储过程,再新建)
  • 测试调用:执行调用存储过程语句(详见下方:管理后台测试调用)

管理后台测试调用

测试调用分为SQL语句和PHP代码

SQL语句:编写并且执行SQL语句进行调用 PHP代码:通过接口大师封装好的代码,只需要编写少量的PHP代码,进行调用

SQL语句

注意:不要用分号(;)结束语句

//如果是输出类型的变量,则不需要单引号
-- MySQL
CALL member_test('test',@m_count)

PHP代码

<?php
$procName = 'member_test'; //存储过程名称
$procParams = array('test','@m_count'); //存储过程传参
$rows = \PhalApi\DI()->databaseProc->call($procName,$procParams);

接口中的使用

编写SQL语句调用

<?php
namespace App\Api;
use App\Common\Api;
// use App\Domain\ProcTest as ProcTestDomain;
/**
 * Proc
 */
class ProcTest extends Api {
    /**
     * 接口参数规则配置
     */
    public function getRules() {
        $rules = parent::getRules();
        $curRules = array(
            'Call' => array(
                // 接口参数规则
            ),
        );
        return array_merge($rules, $curRules);
    }
    /**
     * 存储过程测试
     * @desc 请输入接口功能描述
     * @version 1.0
     *
     */
    public function Call() {
        // 接口参数获取

        // 结果返回
        $rs = array();

        $db = \PhalApi\DI()->databaseManager->init('phalapi_pro');
        $rs = $db->table->queryAll("CALL member_test('test',@m_count)");

        return $rs;
    }

}

返回结果

{
    "ret": 200,
    "data": [
        {
            "m_count": 9
        }
    ],
    "msg": ""
}

用封装好的PHP调用

<?php
namespace App\Api;
use App\Common\Api;
// use App\Domain\ProcTest as ProcTestDomain;
/**
 * Proc
 */
class ProcTest extends Api {
    /**
     * 接口参数规则配置
     */
    public function getRules() {
        $rules = parent::getRules();
        $curRules = array(
            'Call' => array(
                // 接口参数规则
            ),
        );
        return array_merge($rules, $curRules);
    }
    /**
     * 存储过程测试
     * @desc 请输入接口功能描述
     * @version 1.0
     *
     */
    public function Call() {
        // 接口参数获取

        // 结果返回
        $rs = array();
        $procName = 'member_test';
        $procParams = array('test','@m_count');
        $rs = \PhalApi\DI()->databaseProc->call($procName,$procParams);

        return $rs;
    }

}

返回结果

{
    "ret": 200,
    "data": [
        {
            "m_count": 9
        }
    ],
    "msg": ""
}

存储过程的调用统计

管理后台 > 数据库管理 > 存储过程管理 > 编辑(右侧)

修改记录

为了方便找回之前对存储过程的修改,我们也做了保存最近20次修改的历史记录

管理后台 > 数据库管理 > 存储过程管理 > 修改记录

注意事项

  • 在编写调用存储过程SQL语句的时候,不要用分号(;)结束语句
  • 如果SQL语句调用,OUT/INOUT类型的变量,不需要用单引号;例如下面的@m_count CALL member_test('test',@m_count)
  • 表单中的存储过程名称必须与存储过程定义内容里的名称保持一致

接口发布

进入【低代码接口开发】,选择:数据库接口+简易代码模式。下一步:设计接口。

继续填写API接口名称和选择数据库。

继续填写配置接口参数,以及需要调用的存储过程。

最后,保存并发布 接口。确定并发布。

发布后,即可获得标准的API新接口。

演示环境:

演示地址:
http://lite-demo.yesapi.cn/

管理后台:
http://lite-demo.yesapi.cn/admin/

开放平台端:
http://lite-demo.yesapi.cn/platform/

完整产品/技术文档:
http://lite-demo.yesapi.cn/wiki/#/

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言