本文目录一览:
- 1、cakephp save方法怎么一次向数据库插入多条数据?懂cakephp的帮忙解决一下。
- 2、CakePHP怎么写MySQL的IN条件
- 3、cakePHP分页paginate方法的使用
- 4、cakephp本地数据库怎么访问
- 5、国外主流PHP框架对比评测
cakephp save方法怎么一次向数据库插入多条数据?懂cakephp的帮忙解决一下。
您好,是这样的:
$query_num = 10; //可写入的次数,修改该值来决定写入次数。
for($i=1;$i=$query_num;$i++){
mysql_query("insert into table_name (memid,online) values ('25','1')");
}
如果你想灵活控制写入的数据,可以这样做:
function insertvalues ($query_num, $values) {
for($i=1;$i=$query_num;$i++){
mysql_query("insert into table_name (memid,online) values (".$values.")");
}
}
CakePHP怎么写MySQL的IN条件
$conditions[] = array(
'id' = array(1, 2, 3, 4 )
);
可以通过在对应的字段名后面设置一个包含有值的数组来实现与SQL逻辑运算符IN()同等的效果。
cakePHP分页paginate方法的使用
$conditions, $fields, $order, $limit, $page, $recursive, $extra,基本都是字面意思,具体可以查看框架的PaginatorComponent部件-cakephp字段值1
cakephp本地数据库怎么访问
一:find函数是所有模型都具备的一个获取数据的多功能函数,使用语法为:find($type, $params)。$type可以是'all','first','count','list','neighbors'或者'threaded'的其中之一。默认情况下会使用'first'进行查找,即会查出表的第一条符合的数据;本人觉得find("all",条件)或者findByUsername("username名字")/findById(id号)这几种用起来比较顺手,实用点。-cakephp字段值1
实例:
首先我有一张users表和posts表如下:
CREATE TABLE `users` (
`id` int(10) NOT NULL auto_increment,
`username` varchar(50) collate utf8_unicode_ci NOT NULL,
`password` varchar(50) collate utf8_unicode_ci NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=6 ;
--
-- Dumping data for table `users`
--
INSERT INTO `users` (`id`, `username`, `password`) VALUES
(1, 'admin', '4a7d1ed414474e4033ac29ccb8653d9b'),
(2, 'lht', '4a7d1ed414474e4033ac29ccb8653d9b'),
(3, 'test', 'ca5e6aa29fa7ef71e2655b7f797b98e5');
CREATE TABLE `posts` (
`id` int(11) NOT NULL auto_increment,
`user_id` int(11) NOT NULL,
`title` varchar(255) collate utf8_unicode_ci NOT NULL,
`body` text collate utf8_unicode_ci,
`created` datetime default NULL,
`modified` datetime default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=7 ;
--
-- Dumping data for table `posts`
--
INSERT INTO `posts` (`id`, `user_id`, `title`, `body`, `created`, `modified`) VALUES
(2, 1, 'admin''s message', 'Hi,I''m admin.', '2011-06-21 02:06:40', '2011-06-21 02:06:40'),
(3, 3, 'test', 'Just for a test.', '2011-06-21 02:07:44', '2011-06-21 02:07:44'),
(4, 3, 'user1''s title', 'Just for test.', '2011-06-21 02:13:32', '2011-06-21 02:13:32'),
(5, 1, 'user3''title', 'test', '2011-06-21 02:18:39', '2011-06-21 02:18:39'),
(6, 1, '测试', '测试', '2011-06-22 08:43:06', '2011-06-22 08:43:06');
然后我在users控制器的方法test中执行如下语句:
$result = $this-User-find("all",array('id','username','password'));
$this-set("result",$result);
再在test.ctp视图中打印print_r($result ),将可以看到查询数据表的信息如下:
Array
(
[0] = Array
(
[User] = Array
(
[id] = 1
[username] = admin
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
)
[1] = Array
(
[User] = Array
(
[id] = 2
[username] = lht
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
)
[2] = Array
(
[User] = Array
(
[id] = 3
[username] = test
[password] = ca5e6aa29fa7ef71e2655b7f797b98e5
)
)
)
上面所述是查询数据库表所有数据的方法,假如我要查询字段username是admin的,那么我可以用findByUsername(字段名)来查询,如下:
$result = $this-User-findByUsername("admin");然后再打印时将只有username是admin的数据显示,效果如下:
Array
(
[User] = Array
(
[id] = 1
[username] = admin
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
)
查询admin上面那条语句也可以这样写:$result = $this-User-find('all',array('conditions'=array('username'='admin'))),这样也能达到一样的效果,不过我觉得还是findbyusrname()好用点;-cakephp字段值1
假如我们想查询的结果是字段username不是admin的,那要怎么写呢?很简单,需要用到“”这个符号,记得该符号前面要留空格,语句如下:
$result = $this-User-find("all",array('conditions'=array('username '='admin')));
此时打印时admin的那一条数据将不显示,其余都显示:
Array
(
[0] = Array
(
[User] = Array
(
[id] = 2
[username] = lht
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
)
[1] = Array
(
[User] = Array
(
[id] = 3
[username] = test
[password] = ca5e6aa29fa7ef71e2655b7f797b98e5
)
)
)
二:query()函数:
query()函数被设计用来执行自定义的SQL语句,语法query("A"),A即正常使用的sql语句。在query()执行的返回数据中,使用数据表名作为key而非模型(model)名。
实例:
1:向users表中插入一条数据:
$pass = md5(0000);
$this-User-query("insert into `mycake`.`users` (`id`,`username`,`password`) values(null,'adam_li','$pass')");-cakephp字段值1
2:将字段username为admm_li的语句密码更改为0000:
$this-User-query("update `mycake`.`users` set `password`='0000' where `users`.`username`='adam_li'");-cakephp字段值1
3:删除字段username为admm_li的语句:
$this-User-query("delete from `mycake`.`users` where `users`.`username`='adam_li'");
4:用联合查询查出users表与posts表id相同,结果要users表中的所有内容,posts表的body字段:
在test方法中执行:
$this-set("select",$this-User-query("select `mycake`.`users`.*,`mycake`.`posts`.`body` from `users` left join `posts` on `users`.`id`=`posts`.`id`"));-cakephp字段值1
在test.ctp视图中打印$select:pre?php print_r($select); ?/pre,将显示如下:
Array
(
[0] = Array
(
[users] = Array
(
[id] = 1
[username] = admin
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
[posts] = Array
(
[body] =
)
)
[1] = Array
(
[users] = Array
(
[id] = 2
[username] = lht
[password] = 4a7d1ed414474e4033ac29ccb8653d9b
)
[posts] = Array
(
[body] = Hi,I'm admin.
)
)
[2] = Array
(
[users] = Array
(
[id] = 3
[username] = test
[password] = ca5e6aa29fa7ef71e2655b7f797b98e5
)
[posts] = Array
(
[body] = Just for a test.
)
)
)
注意users表的键值显示为users不是模型User。
国外主流PHP框架对比评测
最近简单的使用了目前在国内用的比较多的几个主流国外PHP框架(不包括国内框架) 大致对这些框架有个直观上的感受 简单分享一下 对于哪些做框架选型的时候 权当一个参考
主要参考的框架包括 CodeIgniter CakePHP ZendFramework Symfony 我对很多框架也没有认真使用 只是简单试用了一下 可能很多看法不成熟或者是错误的 请大家指正 一起成长 -cakephp字段值1
CodeIgniter
优点
配置简单 全部的配置使用PHP脚本来配置 执行效率高 具有基本的路由功能 能够进行一定程度的路由 具有初步的Layout功能 能够制作一定程度的界面外观 数据库层封装的不错 具有基本的MVC功能
快速简洁 代码不多 执行性能高 框架简单 容易上手 学习成本低 文档详细 自带了很多简单好用的library 框架适合小型应用
缺点
把Model层简单的理解为数据库操作
框架略显简单 只能够满足小型应用 略微不太能够满足中型应用需要
评价
总体来说 拿CodeIgniter来完成简单快速的应用还是值得 同时能够构造一定程度的layout 便于模板的复用 数据操作层来说封装的不错 并且CodeIgniter没有使用很多太复杂的设计模式 执行性能和代码可读性上都不错 至于附加的 library 也还不错 简洁高效 -cakephp字段值1
CakePHP
优点
CakePHP是最类似于RoR的框架 包括设计方式 数据库操作的Active Record方式 设计层面很优雅 没有自带多余的 library 所有的功能都是纯粹的框架 执行效率还不错 数据库层的 hasOne hasMany 功能很强大 对于复杂业务处理比较合适 路由功能 配置功能还不错 自动构建脚手架(scaffold)很强大 适合中型应用 基本实现过了MVC每一层 具有自动操作命令行脚本功能 -cakephp字段值1
文档比较全 在国内推广的比较成功 大部分都知道CakePHP 学习成本中等
缺点
CakePHP非常严重的问题是把Model理解为数据库层操作 严重影响了除了数据库之外的操作能力
CakePHP的cache功能略显薄弱 配置功能稍嫌弱 CakePHP不适合大型应用 只适合中型应用 小型应用来说略微的学习成本高了点
评价
总体来说CakePHP框架代表了PHP框架很重要的一个时代和代表 并且目前发挥着很重要的作用 不少自己写的框架都模仿了CakePHP的方式 是个里程碑式的产品 CakePHP透露著RoR的敏捷开发方式和把数据库操作认为是唯一Model的设计思想 作为开发快速应用和原型是绝好的工具 同样 用来做Web 网站的开发框架 也是值得选择的 -cakephp字段值1
Zend Framework
优点
官方出品 自带了非常多的 library 框架本身使用了很多设计模式来编写 架构上很优雅 执行效率中等 MVC设计中 比较简洁 具有路由功能 配置文件比较强大(能够处理XML和php INI) 各种 library 很强大 是所有PHP框架中各种功能最全面的 包括它不仅是一个框架 更是一个大类库(取代PEAR) 这是它的主要特色 能够直观的支持除数据库操作之外的Model层(比 CodeIgniter 和 CakePHP 强) 并且能够很轻易的使用Loader功能加载其他新增加的Class Cache功能很强大 从前端Cache到后端Cache都支持 后端Cache支持Memcache APC SQLite 文件等等方式 数据库操作功能很强大 支持各种驱动(适配器)-cakephp字段值1
文档很全 在国内社区很成熟 并且目前不少Web 网站在使用 学习成本中等
缺点
MVC功能完成比较弱 View层简单实现(跟没实现一样) 无法很强大的控制前端页面
没有自动化脚本 创建一个应用 包括入口文件 全部必须自己手工构建 入门成本高
Zend Framework 作为一个中型应用框架问题不大 也能够勉强作为大型应用的框架 但是作为一个很成熟的大型PHP框架来说 还需要一些努力
评价
作为官方出品的框架 Zend Framework的野心是可以预见的 想把其他框架挤走 同时封装很多强大的类库 能够提供一站式的框架服务 并且他们的开发团队很强大 完全足够有能力开发很强大的产品出来 所以基本可以确定的是Zend Framework前途无量 如果花费更多的时间去完善框架 同样的 Zend Framework架构本身也是比较优雅的 说明Zend官方是有很多高手的 设计理念上比较先进 虽然有一些功能实现的不够完善 比如View层 自动化脚本等等 这些都有赖于未来的升级 总体来说Zend Framework是最值得期待的框架 当然 你目前要投入你的项目中使用也是完全没问题的 -cakephp字段值1
Symfony
优点
Symfony 是我了解的PHP框架中功能最强大的 而且我使用时间比较长 但是很多功能还是没有挖掘出来 它完整实现了MVC三层 封装了所有东西 包括 $_POST $_GET 数据 异常处理 调试功能 数据检测 包含强大的缓存功能 自动加载Class(这个功能很爽) 强大的i n国家化支持 具有很强大的view层操作 能够零碎的包含单个多个文件 非常强大的配置功能 使用yml配置能够控制所有框架和程序运行行为 强大到让人无语 能够很随意的定义各种自己的class 并且symfony能够自动加载(auto load)这些class 能够在程序中随意调用 包含强大的多层级项目和应用管理 Project Application Module Action 能够满足一个项目下多个应用的需要 并且每层可以定义自己的类库 配置文件 layout 非常强大的命令行操作功能 包括建立项目 建立应用 建立模块 刷新缓存等等 -cakephp字段值1
Symfony绝对是开发大型复杂项目的首选 因为使用了Symfony 将大大节约开发成本 并且多人协作的时候 不会出现问题 在Project级别定义好基础Class以后 任何模块都能够重用 大大复用代码-cakephp字段值1
缺点
数据库操作model采用了重量级的propel和creole 不过在我测试的版本中已经把他们移到了addon里 可用可不用
缓存功能无法控制 每次开发调试总是缓存 需要执行 symfony cc symfony rc 来清除和重建缓存
效率不是很高 特别是解析模板和读取配置文件的过程 花费时间不少
学习成本很高 并且国内没有成熟的社区和文档 连中文手册都没有 相应的要掌握所有功能 需要花费比较多的时间
评价
Symfony绝对是企业级的框架 唯一能够貌似能够跟Java领域哪些强悍框架抗衡的东西 强悍的东西 自然学习复杂 但是相应的对项目开发也比较有帮助 自然是推荐复杂的项目使用Symfony来处理 觉得是值得 后期的维护成本比较低 复用性很强 相应的如果使用Symfony的应该都是比较复杂的互联网项目 那么相应的就要考虑关于数据库分布的问题 那么就需要抛弃Symfony自带的数据库操作层 需要自己定义 当然了 Symfony支持随意的构造model层 -cakephp字段值1
总结
以上数款框架 各有特色 而且都是开源项目 不过框架针对的项目不一样 一般来说 CodeIngiter 比较适合小型项目 CakePHP 和 Zend Framework 比较适合中型项目 Symfony 比较适合大型重量级项目 在项目选型的时候 要充分考虑框架的可以定制性 扩展性 因为每个项目都无法确定你是否会随着需求的变化进行改变 -cakephp字段值1
相对来说 Zend Framework 和 Symfony 应对变化的能力比较强 特别是能够随意定制 model 层的Class 能够非常方便增加自己业务或者数据处理类 我是个人比较推荐在中大型项目中使用的框架 -cakephp字段值1
CodeIngiter 和 CakePHP 在中小型项目中同样能够发挥重大作用 快速开发和原型构建 非常适合目标不清晰的原型项目的开发
当然了 也许 自己写一个框架更适合
lishixinzhi/Article/program/PHP/201311/21441