kohana 简单使用
声明:基于公司使用的 Kohana 框架写的,不确定是否适用于原生 Kohana
附:Kohana 3 中文手册,传送门:http://www.lampblog.net/kohana3%E4%BD%BF%E7%94%A8%E6%89%8B%E5%86%8C/
1)请求和响应
1.1)获取请求参数
获取$_GET 或 $_POST 之类的全局变量:
$this->response->get() 、$this->response->post();
数组变量获取和空处理:
Arr::get($this->request->post(), 'user_name', ''); Arr::get($this->request->get(), 'page', 1);
注:三个参数分别是:要处理的数组、变量key、为空时返回值
1.2)响应模版或json
显示模版:
$this->view('user_index');
1.2.1)输入变量到模版
$this->view('user_index') ->set('user_info', $user_info) ->set('order_status_nums', $order_status_nums);
1.2.2)公共头和脚
\modules\module\classes\template.php 类里 get_header_view 和 get_footer_view 分别处理公共头部和公共脚部
1.3)重定向跳转
$this->request->redirect($url);
2)session 和 cookie
2.1)使用 session
Session::instance()->set('user_id', $user_id);
Session::instance()->get('user_id');
2.2)使用 cookie
Cookie::instance()->set('user_id', $user_id);
Cookie::instance()->get('user_id');
3)数据库操作
3.1)增(DB::insert())
DB::insert(‘table_name’, array(‘column’))->values(array(‘column_value’))->execute();
如果命令成功,你就能得到一个包含 insert_id 和 total_rows (总共影响到的行数)组成的数组
3.2)删(DB::delete())
$total_rows = DB::delete(‘table_name’)->where(‘column’,’=’,’value’)->execute();
如果命令成功,你就能得到结果中影响到的行数
3.3)改(DB::update())
$total_rows = DB::update(‘table_name’)->set(array(‘column’=>’value’))->where(‘column’,’=’,’value’)->execute();
如果命令成功,你就能得到结果中影响到的行数
3.4)查(DB::select())
$result = DB::select()->from(‘table_name’)->where(‘column’,’=’,’value’)->execute()->as_array();
3.4.1)查询一行
$result = DB::select('column')->from('table_name')->execute()->current();
3.4.2)字段别名
$result = DB::select(array('longcolumnname1', 'col1'), array('longcolumnname2', 'aliascol2'))->from('table_name')->execute()->as_array();
3.5)使用原生 sql
$arr = DB::query ( Database::SELECT, $sql )->execute()->as_array();
query 方法的第一个参数是操作类型,可选值为:Database::SELECT、Database::INSERT、NULL
类型为select时返回结果集,类型为insert时返回insert_id,类型为null 或 其他值 时返回影响的行数
3.6)打印上一条查询的 sql
ORM 或 Model 可使用 last_query() 方法获取上一条查询语句
Database::instance()->last_query
3.7)sql 预处理
DB->select('col1','col2')->form('table_name')->where('user_id', '=', ':id')->param(':id', 1)->execute()->as_array();
3.8)排序与分页
$results = DB::select()->from('users')->order_by('id','desc')->limit($page_size)->offset($offset)->execute();
4)service 和 dao
service 和 dao 不是必用项,可以按息要求和习惯写或不写都可以,它们本质就是封闭了一些 DB 操作方法(函数)
公共service 和 dao 分别位于 /modules/module/classes/service/ 和 /modules/module/classes/dao/ 下,你也可以在本应用的 classes 下新建 service 和 dao 来覆盖公共的类(优先级比公共的高)
完
kohana 简单使用的更多相关文章
- Kohana 数据库
只要不使用官方网站的教程,自己摸索出来的,有一个错误,当我们指了出来,哦,,好吧共同进步~ 首先配置:modules\database\config\database.php <?php 'de ...
- kohana task 编写计划任务
kohana 框架 我们经常使用gleez作为我们二次开发. 收先我们要把文件建在Task文件夹下,比如新建文件为:testcron <?phpdefined('SYSPATH') or di ...
- 【造轮子】打造一个简单的万能Excel读写工具
大家工作或者平时是不是经常遇到要读写一些简单格式的Excel? shit!~很蛋疼,因为之前吹牛,就搞了个这东西,还算是挺实用,和大家分享下. 厌烦了每次搞简单类型的Excel读写?不怕~来,喜欢流式 ...
- Fabio 安装和简单使用
Fabio(Go 语言):https://github.com/eBay/fabio Fabio 是一个快速.现代.zero-conf 负载均衡 HTTP(S) 路由器,用于部署 Consul 管理的 ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- 哪种缓存效果高?开源一个简单的缓存组件j2cache
背景 现在的web系统已经越来越多的应用缓存技术,而且缓存技术确实是能实足的增强系统性能的.我在项目中也开始接触一些缓存的需求. 开始简单的就用jvm(java托管内存)来做缓存,这样对于单个应用服务 ...
- 在Openfire上弄一个简单的推送系统
推送系统 说是推送系统有点大,其实就是一个消息广播功能吧.作用其实也就是由服务端接收到消息然后推送到订阅的客户端. 思路 对于推送最关键的是服务端向客户端发送数据,客户端向服务端订阅自己想要的消息.这 ...
- 我的MYSQL学习心得(一) 简单语法
我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- 使用 Nodejs 搭建简单的Web服务器
使用Nodejs搭建Web服务器是学习Node.js比较全面的入门教程,因为要完成一个简单的Web服务器,你需要学习Nodejs中几个比较重要的模块,比如:http协议模块.文件系统.url解析模块. ...
随机推荐
- Matlab函数——std,std2与mean,mean2区别
最近看代码,经常看到std,std2的用法,由于刚刚学习,网上搜索了下,没有找到解答,看了help,s = std(X,flag)s = std(X,flag,dim) ,只告诉我们 flag,di ...
- Python 引用
python引用python中的数值类型变量也是引用,例如: a = 100b=a那么a和b指向同一块内存但是当修改a或者b的值得时候,Python会新分配一块内存来存储新的值 python中不可变类 ...
- VMware虚拟机找不到USB设备
VMware虚拟机找不到USB设备该怎么办?打开虚拟机发现竟然找不到usb设备,键盘和鼠标都是usb的,这该怎么办呢?出现这个问题是因为VMUSBArbService服务没有开启,下面分享开启的方法 ...
- USB2.0学习笔记连载(十四):USB驱动安装及固件程序的编写
在之前的博客中已经讲过,驱动程序最核心的两个文件,一个是xxx.sys文件,一个是xxx.inf文件,主机是寻找xxx.inf文件. 在下面的文件中有相关关于USB驱动的说明.对于用户来说,xxx.s ...
- 关于Unity中的本地存储
本地存储 在做游戏的时候,经常需要在本机存储一些数据,比如闯关类游戏要记录闯到第几关,做单机的时候要把数据保存到本地,下次启动的时候数据存在,就是把数据保存到磁盘里面或者手机的flash闪存里面. U ...
- 《深入理解Java虚拟机》读书笔记:Java内存区域
xmind文件下载地址
- Java如何以(MMM)格式显示一个月份的名称?
JAVA中,如何以(MMM)格式显示一个月份的名称? 此示例显示如何使用Calender类的Calender.getInstance()方法和Formatter类的fmt.format()方法来显示( ...
- OpenMP并行编程应用—加速OpenCV图像拼接算法
OpenMP是一种应用于多处理器程序设计的并行编程处理方案,它提供了对于并行编程的高层抽象.仅仅须要在程序中加入简单的指令,就能够编写高效的并行程序,而不用关心详细的并行实现细节.减少了并行编程的难度 ...
- Linux 定时任务crontab_014
1. crontab命令概念 crontab命令用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行. cron 系统调度进程. 可以使 ...
- ggplot2 提取stat计算出来的数据
使用ggplot2 绘图时,我们只需要提供原始数据就可以了,ggplot2 内置了许多的计算函数,来帮助我们计算对应的数值. 最典型的的,当使用geom_boxplot 绘制箱线图时,我们只提供原始数 ...