Laravel的Eloquent有什么特点
看了官方文档,感觉eloquent这种ORM基本上所有框架都有做啊,链式调用什么的根本就不是特点啊,其它框架都封装了各种数据库操作。为什么说eloquent是laravel非常强大的地方,它有什么特点吗
回复内容:
看了官方文档,感觉eloquent这种ORM基本上所有框架都有做啊,链式调用什么的根本就不是特点啊,其它框架都封装了各种数据库操作。为什么说eloquent是laravel非常强大的地方,它有什么特点吗
简单,高效,优雅
基本特性
<code>php</code><code>User::first(); // 得到第一个 User 对象 User::find(10); // 得到 id = 10 的 User 对象 User::where('name', 'john')->first(); // 得到第一个 name = john 的 User 对象 User::where('name', 'john')->get(); // 得到 name = john 的 User 对象组 User::where('name', 'john')->get()->toArray(); // 得到 name = john 的 User 对象数组 Article::where('id', '>=', 10)->where('id', 'orderBy('updated_at', 'desc')->get(); // 得到 Article id 在 10~20 的对象组 </code>
高级特性
分页
后端代码:
<code>php</code><code>return View::make('users')->withUsers(User::paginate(20)); </code>
前端代码 users.blade.php:
<code>php</code><code><br><br><ul> @foreach ($users as $user) <li> id:{{ $user->id }} name:{{ $user->name }} </li> @endforeach </ul> {{ $users->links() }} </code>
Laravel 会自动生成分页指示器及链接,自动维护。分页功能已经彻底完成。
模型间关系
以一对多关系举例,获得 id = 10 的用户写过的所有文章:
<code>php</code><code>class User extends Eloquent { protected $table = 'users'; public function hasManyArticles() { return $this->hasMany('Article', 'user_id', 'id'); } } </code>
取得:
<code>php</code><code>$userWithArticles = User::find(10)->hasManyArticles()->get(); </code>
结果:$userWithArticles 是一个标准的 User 对象,外加 $userWithArticles->hasManyArticles 的值为该用户写的所有文章的对象组。
关于更多模型间关系可以参考:深入理解 Laravel Eloquent(三)——模型间关系(关联)
比较“现代化”的这些php框架,文案都是针对原来不用框架/不用ORM的程序员写的,相对于直接拼SQL,Eloquent当然在功能上很强大,但相对与同属ActiveRecord的Propel和Mapper/Proxy模式的Doctrine,没有质的差别。
增删改查就不说了,说几个其他框架可能没有的
1.relation时的预载入
用来减少了ORM的N + 1 查询问题
2.缓存
反复执行User::find(1),sql执行一次。
3.模型观察者
使用了观察者模式,监听模型的操作。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



LaravelEloquent Model Retrieval: Easily obtaining database data EloquentORM provides a concise and easy-to-understand way to operate the database. This article will introduce various Eloquent model search techniques in detail to help you obtain data from the database efficiently. 1. Get all records. Use the all() method to get all records in the database table: useApp\Models\Post;$posts=Post::all(); This will return a collection. You can access data using foreach loop or other collection methods: foreach($postsas$post){echo$post->

The future of PHP will be achieved by adapting to new technology trends and introducing innovative features: 1) Adapting to cloud computing, containerization and microservice architectures, supporting Docker and Kubernetes; 2) introducing JIT compilers and enumeration types to improve performance and data processing efficiency; 3) Continuously optimize performance and promote best practices.

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP remains important in modern web development, especially in content management and e-commerce platforms. 1) PHP has a rich ecosystem and strong framework support, such as Laravel and Symfony. 2) Performance optimization can be achieved through OPcache and Nginx. 3) PHP8.0 introduces JIT compiler to improve performance. 4) Cloud-native applications are deployed through Docker and Kubernetes to improve flexibility and scalability.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

Efficiently process 7 million records and create interactive maps with geospatial technology. This article explores how to efficiently process over 7 million records using Laravel and MySQL and convert them into interactive map visualizations. Initial challenge project requirements: Extract valuable insights using 7 million records in MySQL database. Many people first consider programming languages, but ignore the database itself: Can it meet the needs? Is data migration or structural adjustment required? Can MySQL withstand such a large data load? Preliminary analysis: Key filters and properties need to be identified. After analysis, it was found that only a few attributes were related to the solution. We verified the feasibility of the filter and set some restrictions to optimize the search. Map search based on city

How does Laravel play a role in backend logic? It simplifies and enhances backend development through routing systems, EloquentORM, authentication and authorization, event and listeners, and performance optimization. 1. The routing system allows the definition of URL structure and request processing logic. 2.EloquentORM simplifies database interaction. 3. The authentication and authorization system is convenient for user management. 4. The event and listener implement loosely coupled code structure. 5. Performance optimization improves application efficiency through caching and queueing.

The reasons why PHP is the preferred technology stack for many websites include its ease of use, strong community support, and widespread use. 1) Easy to learn and use, suitable for beginners. 2) Have a huge developer community and rich resources. 3) Widely used in WordPress, Drupal and other platforms. 4) Integrate tightly with web servers to simplify development deployment.
