这篇文章给大家聊聊关于laraveladmin中文文档,以及laravel框架面试题对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。
tp5的fastadmin适合快速开发吗
很适合fastadmin可以一键生成crud开发效率极高,非常适合快速开发。我最近刚在fastadmin插件市场上架了一款插件。
laravel框架中的Model操作数据库 , 相比DB类有什么明显的优越性吗
引言
我们推荐使用laravel的eloquentorm模型操作数据库表,因为特性更为丰富,组装更为灵活,在编程层面操作数据的来来去去非常直观。而有些场景不可避免地与原生交互,我们本期就来梳理一下DB门面相关的那些方法。
学习时间
系统提供了DB门面用于原生的SQL操作,在程序内引入下面的类:
useIlluminate\Support\Facades\DB;
该类的定义很简单,标准的门面注册方法:
classDBextendsFacade{protectedstaticfunctiongetFacadeAccessor(){return'db';}}
仅实现了getFacadeAccessor方法,这些类处于同一个命名空间下的Facade.php文件内。
DB门面既可以使用querybuilder的链式操作,也可以用于执行原生查询。举几个例子。比如删除users表:
DB::statement('droptableusers');
带参数绑定的SQL查询语句:
DB::select('select*fromcontactswherevalidated=?',[1]);
或者使用链式操作,获取所有满足条件的记录:
$users=DB::table('users')->get();
当然了,还有经常用到的多表联合查询,复杂的查询过滤条件:
DB::table('users')->join('contacts',function($join){$join->on('users.id','=','contacts.user_id')->where('contacts.type','donor');})->get();
CRUD
上一节是一些简单示例,下面我们说一说增删改查的用法。先说查询语句,如果在数据库优化上做的比较好的一些SQL固定写法,可以使用原生方法固化下来。比如简单的:
$users=DB::select('select*fromusers');
该方法会返回一个标准对象的集合。扩展一下,带有查询条件的SQL原生语句,为了防止SQL注入,使用参数绑定的方式:
$usersOfType=DB::select('select*fromuserswheretype=?',[$type]);
当然也可以使用PDO常用的方式占位:
$usersOfType=DB::select('select*fromuserswheretype=:type',['type'=>$userType]);
插入新数据,其实与上述的带有占位符参数绑定的SQL查询语句类似,只是SQL语法不同而已:
DB::insert('insertintocontacts(name,email)values(?,?)',['salt','salt@lot.com']);
更新数据也是一样的:
$countUpdated=DB::update('updatecontactssetstatus=?whereid=?',[1,$id]);
当然了,删除语句仅仅需要where子句的条件参数绑定,其他与查询select无异:
$countDeleted=DB::delete('deletefromcontactswherearchived=?',[1]);
写在最后
本文通过对laravelDB门面的增删改查用法,向大家展示了基本的参数绑定的用法。一般我们不推荐使用原生SQL语句操作数据库,提倡大家把数据库操作集中到模型层,充分利用eloquentorm的性能。
Happycoding:-)
我是@程序员小助手,持续分享编程知识,欢迎关注。
关于本次laraveladmin中文文档和laravel框架面试题的问题分享到这里就结束了,如果解决了您的问题,我们非常高兴。