## 存储过程
由于数据库操作接口的不统一,所以存储过程调用的方法上有一点差别。
> 后续会为YurunPHP引入PDO方式的数据库操作。
格式:
~~~
execProc([存储过程名][,[参数][,[参数类型]]])
~~~
| 名称 | 描述 |
| -- | -- |
| 存储过程名 | 要执行的存储过程名 |
| 参数 | 传递给存储过程的参数,一维数组形式 |
| 参数类型 | 可选值查看下表,留空不填则会从配置文件中读取,如果传参和配置中都为空,则查询时不是使用预处理 |
| 字符 | 描述 |
| -- | -- |
| i | 整数类型 |
| d | 浮点类型 |
| s | 字符串类型 |
| b | 二进制类型 |
### MySQL API
MYSQL API不支持INOUT和OUT参数。
代码:
~~~
// 调用无参数的存储过程
$this->db->execProc('存储过程名');
// 调用有参数的存储过程
$this->db->execProc('存储过程名',array('宇润','无锡'));
~~~
### MySQLi
MYSQLi支持INOUT和OUT参数。
用法:
~~~
$this->db->execProc([存储过程名][,参数]);
~~~
代码:
~~~
// 调用无参数的存储过程
$this->db->execProc('存储过程名');
// 调用有参数的存储过程
$this->db->execProc('存储过程名',array('宇润','无锡'));
// 调用有参数的存储过程,并且获得OUT参数返回值。存储过程的三个参数类型分别是字符串、字符串和整数型,所以根据上表是ssi
$this->db->execProc('存储过程名',array('宇润','无锡',&$age),'ssi');
~~~
### 配置文件中配置存储过程的参数:
~~~
<?php
return array(
'DbProc' => array(
'存储过程名' => array(
'params' => 'ssi'
),
'存储过程名2' => array(
'params' => 'iiii'
),
)
);
~~~
直接执行:
~~~
// 调用有参数的存储过程,并且获得OUT参数返回值。
$this->db->execProc('存储过程名',array('宇润','无锡',&$age));
~~~
- 序言
- 有些话想说
- 基础入门
- 简介
- 下载安装YurunPHP
- 运行环境
- 开发规范
- 目录结构
- 模块
- 控制器
- 自动加载
- 手动加载
- 项目配置
- 入口文件
- 项目目录结构
- 配置文件
- 驱动配置
- 数据库配置
- 项目初始化处理
- 框架编译
- 项目部署
- 控制器
- 创建控制器
- 加载模版显示页面
- AJAX返回数据
- 模型
- 创建模型
- 实例化模型
- 数据管理
- 连贯操作
- distinct
- field
- from
- where
- wherePk
- group
- having
- order
- limit
- join
- page
- headTotal/footTotal
- 连贯操作收尾方法
- select
- selectPage
- buildSQL
- selectValue
- selectBy
- getBy
- getByPk
- random
- inc
- dec
- add
- edit
- delete
- 合计函数
- save
- 执行SQL语句
- 创建数据并验证
- 字段映射
- 增删改查前置和后置
- Response类
- GET/POST/COOKIE/REQUEST
- Cookie
- Session
- 如何自定义Session存储
- 数据库操作
- 常用操作
- 查询记录
- 存储过程
- 数据库函数
- MSSQL
- 视图
- 调用视图
- 给视图传值
- 模版引擎
- 输出
- 使用PHP代码
- 模版标签
- if
- switch
- for
- counter
- foreach
- include
- js/css/image
- url
- origin
- 模版常量替换
- 后台视图控件
- 通用属性用法
- 数据集绑定
- 下拉框(select)
- 单选框(radio)
- 单选框组(radiogroup)
- 选择框(checkbox)
- 选择框组(checkboxgroup)
- 表格(table)
- 文本框(textbox)
- 分页条(pagebar)
- 数据验证
- 验证方法
- between
- betweenEqual
- empty_str
- not_empty_str
- regex
- length
- lengthChar
- mobile
- tel
- phone
- postcode
- url
- ip
- lt/gt/ltEqual/gtEqual
- equal/unequal
- in/notin
- idcard
- 路由
- 路由配置
- 自定义分层
- 缓存
- 缓存配置
- 使用缓存
- 配置
- 配置驱动配置
- 使用配置
- 过滤域名
- 日志
- 日志驱动配置
- 文件日志
- 事件
- 事件列表
- 插件
- 多语言支持
- 定时任务
- API接口开发
- CLI命令行模式
- Soap WebService