我们的数据库常常都是很庞大的,一次查询的结果集也很大,这样很浪费内存,为了降低内存的使用率,我们可以使用yii2的batch和each方法。
为了让大家看的更明白,我们模拟一个场景,然后通过yii2的debug来查看all与batch/each方法下的内存使用情况。
开始准备
我们先建立一张表,它很简单。
你看到了,它有主键id、会员名username、所在省province,现在它是空的。
然后,我们执行了一个循环
set_time_limit(0); for($i=1;$i<=10000;$i++){ Yii::$app->db->createCommand()->insert("user",[ 'username'=>'abei'.$i, 'province'=>'北京市' ])->execute(); }
执行后,你知道我们的数据库里有10000条记录了,现在我们开始对比。
对比
为了方便,我们在视图里直接写循环体,如下面代码,你一定可以看懂。
$query = new \yii\db\Query(); $query->from('user'); foreach($query->all() as $user){ echo $user['username']; echo "<br/>"; }
结果那?
占有内存 15.306MB
OK,现在开始看看batch和each的戏法,到底有没有节省内存。
$query = new \yii\db\Query(); $query->from('user'); foreach($query->batch() as $users){ foreach($users as $user){ echo $user['username']; echo "<br/>"; } }
结果那?
果然,节省了一半的内存。现在仅仅占用了8.077MB
同样的
$query = new \yii\db\Query(); $query->from('user'); foreach($query->each() as $user){ echo $user['username']; echo "<br/>"; }
each的表现也相当不错
结果
当我们遇到需要一次读取出所有的或是大批量数据的时候,可以考虑使用batch和each,这一点点代码的优化帮你省掉了一半的内存。
PHP中文网,有大量免费的Yii入门教程,欢迎大家学习!
以上是yii2 batch和each的区别是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

Yii框架在众多PHP框架中依然保持强大生命力是因为其高效、简洁和可扩展的设计理念。1)Yii通过“约定优于配置”提高开发效率;2)基于组件的架构和强大的ORM系统Gii增强了灵活性和开发速度;3)性能优化和不断的更新迭代确保其持续竞争力。

Yii在现代Web开发中仍适用于需要高性能和灵活性的项目。1)Yii基于PHP的高性能框架,遵循MVC架构。2)它的优势在于高效、简洁和组件化设计。3)性能优化主要通过缓存和ORM实现。4)随着新框架的出现,Yii的使用情况有所变化。

Yii和PHP可以打造动态网站。1)Yii是一个高性能的PHP框架,简化Web应用开发。2)Yii提供MVC架构、ORM、缓存等功能,适合大型应用开发。3)使用Yii的基本和高级功能可以快速构建网站。4)注意配置、命名空间和数据库连接问题,使用日志和调试工具进行调试。5)通过缓存和优化查询提升性能,遵循最佳实践提高代码质量。

Yii框架在PHP框架中脱颖而出,其优势包括:1.MVC架构和组件化设计,提升代码组织和复用性;2.Gii代码生成器和ActiveRecord,提高开发效率;3.多种缓存机制,优化性能;4.灵活的RBAC系统,简化权限管理。

Yii仍然是开发者的一个强有力的选择。1)Yii是一个高性能的PHP框架,基于MVC架构,提供ActiveRecord、Gii和缓存系统等工具。2)它的优点包括高效性和灵活性,但学习曲线较陡,社区支持相对有限。3)适合需要高性能和灵活性的项目,但需考虑团队技术栈和学习成本。

Yii框架适用于企业级应用、中小型项目和个人项目。1)在企业级应用中,Yii的高性能和可扩展性使其在电商平台等大型项目中表现出色。2)中小型项目中,Yii的Gii工具帮助快速搭建原型和MVP。3)个人项目和开源项目中,Yii的轻量级特性使其适合小型网站和博客。

Yii框架适合构建高效、安全和可扩展的Web应用。1)Yii基于MVC架构,提供组件化设计和安全特性。2)它支持基本CRUD操作和高级RESTfulAPI开发。3)提供日志记录和调试工具栏等调试技巧。4)建议使用缓存和延迟加载进行性能优化。

Yii的目的是让开发者快速、高效地构建Web应用。其实现通过以下方式:1)组件化设计和MVC架构提高代码可维护性和可重用性;2)Gii工具自动生成代码,提升开发速度;3)延迟加载和缓存机制优化性能;4)灵活的扩展性便于集成第三方库;5)提供RBAC功能处理复杂业务逻辑。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载
最流行的的开源编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

禅工作室 13.0.1
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能