关于laravel的介绍就不讲了,总之laravel是款比较强大的框架,它是国外框架所以在安装的上面可能比较麻烦。
laravel的安装
首先安装laravel之前要安装composer,如果是linux系统即可直接下载安装,下载完后不能安装记得修改下文件权限用命令chmod,这边主要讲下window下如何使用composer这个工具。
首先百度搜索中国composer镜像,就可以找到composer config -g repositories.packagist composer
http://packagist.phpcomposer.com这条命令,运行cmd在命令行运行上面的命令,就可以下载composer工具,
下载成功后可以看到composer文件底下有个composer.json文件这是一个配置文件,打开配置文件写明php版本信息和要下载的laravel信息,格式如下:
{ "name": "laravel/laravel", "description": "The Laravel Framework.", "keywords": ["framework", "laravel"], "license": "MIT", "type": "project", "require": { "php": ">=5.5.9", "laravel/framework": "5.1.*" }, "require-dev": { "fzaninotto/faker": "~1.4", "mockery/mockery": "0.9.*", "phpunit/phpunit": "~4.0", "phpspec/phpspec": "~2.1" }, "autoload": { "classmap": [ "database" ], "psr-4": { "App\\": "app/" } }, "autoload-dev": { "classmap": [ "tests/TestCase.php" ] }, "scripts": { "post-install-cmd": [ "php artisan clear-compiled", "php artisan optimize" ], "pre-update-cmd": [ "php artisan clear-compiled" ], "post-update-cmd": [ "php artisan optimize" ], "post-root-package-install": [ "php -r \"copy('.env.example', '.env');\"" ], "post-create-project-cmd": [ "php artisan key:generate" ] }, "config": { "preferred-install": "dist" }, "repositories": [ {"type": "composer", "url": "http://packagist.phpcomposer.com"}, {"packagist": false} ] }```
配置好之后输入composer install 进行安装laravel,这边要比较注意的是安装目录的路径问题,如果你想安装在d盘底下就在把命令行切到d目录底下进行安装(在此操作之前要配置好环境变量)。
laravel的目录结构介绍
安装完的第一次肯定是要想怎么去运行它,很简单,直接进入public文件就可以打开一个开始页面,如果在本地的话那就是localhost/laravelproject/public,就可以运行。
接下来介绍下laravel目录结构,首先介绍下public的index.php文件 里面主要是加载了开始文件然后才能成功运行laravel,具体的两个文件你可以在根目录下bootstrap文件夹中找到。现在看下app中的结构:
view中主要放的是视图文件(创建文件时要用到blade模板,比如创建test.blade.php,laravel中是结合blade模板引擎来调用视图模板)
controller放的是控制器(手动创建时记得要用composer 命令进行更新)
config中主要是配置文件(比如配置数据库时要用到database.php文件)
models主要是放模型(也就是数据库的表)
routes则是路由配置,
filters则是过滤器。
laravel是怎么运行的
刚学习时肯定是要先尝试下如何运行这个laravel,首先手动创建一个controller,文件命名为TestController.php,然打开命令行进入项目的根目录下 执行 composer dumpautoload,里面内容可以模仿homeController.php。
然后编辑routes.php文件,将原来的Route::GET(‘/’,function()…);修改为Route::Get(‘/’,’TestController@showWelcome’); 然后运行也会跳到laravel欢迎界面。
如果Route::Get(‘test’,’TestController@showWelcome’);则在网站根目录下后面直接增加test就可以访问了,到了这里应该明白了怎么到Controller,Controller怎么到View了。
laravel数据库配置
这边用到的是mysql,进行了简单的配置
'mysql' => array( 'driver' => 'mysql', 'host' => 'localhost', 'database' => 'oss', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', )
laravel的数据库使用
<?php use Illuminate\Auth\UserTrait; use Illuminate\Auth\UserInterface; use Illuminate\Auth\Reminders\RemindableTrait; use Illuminate\Auth\Reminders\RemindableInterface; class User extends Eloquent implements UserInterface, RemindableInterface { use UserTrait, RemindableTrait; /** * The database table used by the model. * * @var string */ protected $table = 'users'; /** * The attributes excluded from the model's JSON form. * * @var array */ protected $hidden = array('password', 'remember_token'); }
即可以直接使用 User ::all() 查询所有结果 ,User::find(2)查询一个,Post::findOrFail(2)
如果没找到就会返回错误,Post::save()、Post::where()->find()、Post::add()、Post::delete()
数据库的简便操作:
DB::table(‘tablename’)->insert([ 插入多个时要再加一个数组 ['title'=>'title','name'=>'name'] ['title'=>'title'] ['title'=>'title'] ]) 插入时要想得到ID DB::table('tablename')->insertGetId(['title'=>'titles']) 更新数据要有ID DB::table('tablename')->where('id',1)->update(['title'=>'titles']) 删除数据 DB::table('tablename')->where('id',1)->delete(); 查询数据 DB::table('tablename')->get(); 得到全部的值 DB::table('tablename')->get(['title']); 只查询title的值 DB::table('tablename')->first(); 只拿第一个 DB::table('tablename')->orderBy('id','desc')->first(); 根据id排序 DB::table('tablename')->where('id','!=',2)->get(); 不等于2 DB::table('tablename')->where('id','!=',2)->where('id','>',5)->get(); 可以使用多个where DB::table('tablename')->where('id','!=',2)->OrWhere('id','>',5)->get(); 或者 DB::table('tablename')->whereBetween('id',[2,5])->get(); 闭包之间 DB::table('tablename')->whereIn('id',[2,5,9])->get(); DB::table('tablename')->whereNotIn('id',[2,5,9])->get(); DB::table('tablename')->whereNull('id')->get(); 为空的话就可以查询出来 DB::table('tablename')->take(3)->get(); 只查询3个 DB::table('tablename')->limit(3)->get(); 只查询3个 DB::table('tablename')->skip(2)->take(3)->get(); 只查询3个跳过第二个 DB::table('tablename')->where('id','!=',2)->pluck('title'); 只返回它的title DB::table('tablename')->count(); 有多少条记录 DB::table('tablename')->max('id'); DB::table('tablename')->min('id'); DB::table('tablename')->avg('id'); DB::table('tablename')->sum('id');
多表关联
在Post中定义
public function comment(){ return $this->hasMany('Comment','post_id') } 正向关联 一对多 一对一是hasOne
在Comment中定义
public function post(){ return $this->belongsTo('Post','post_id') } 反向关联
取得关联值
Post::find(2)->comment 就可以得到Comment这张表的内容 //这样查询一个是可以的 查询多个就要设置预载入 查询多个 Post::with('comment')->get(); Post::with(['comment'=>function($query){$query->where('id','>',2)}])->get(); 加条件
感谢大家的阅读,希望大家有所收益。
本文转自:https://blog.csdn.net/Happy_CSDN/article/details/49363219
推荐教程:《php教程》
위 내용은 PHP에서 laravel 프레임워크를 배우는 방법(초보자)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

LARAVEL10INTRODICESEREVERALKEYFEATERESTERETHANCEBEDEVENCENTMENT.1) LazyCollectionsallowEctiversityProcessingoflargedAgestoutSwithoutlakestougleswithoutlakeStiSwithoutloUgentswithoutloWeDAtSwithOUdlingAllRecordsIntomemory.2) The'Make : Model 및 Mightration 'and Mighting'and Mighting 'and Megigation'ArtisAncommandSimplifiesmomodelSandmagrations.3) Integration

laravelymigrations는 eTheystreamlinedevelopment, ensereconsconsencyacrossenvironments 및 simplifycollaborationanddeployment.1) theavergrammationmanagementofdatabaseSchemachanges, rowingerrors.2) MigrationsCanbeverSioncontrolled, ensurin

예, laravelmigrationisworthsing.itsimplifiesDatabaseSchemamanagemanagement, EnhanceScollaboration 및 provostversionControl.useitForstructured, 효율적인 개발.

SoftDeletesInlaravelImpActPerformanceByplicatingQueriesandincreasingStorageneeds.tomitigateSeissues : 1) INDEXTHEDETEDEDEDED_ATCOLUMNTOSPEEDUPQUERIES, 2) useEgerLoadTuceQueryCount 및 3) 정기적으로 클레어 업 소프트-드레인드 리코드 스토 파이어를 유지합니다

laravelmigrationsearebeneficialforversontrol, 협업 및 프로모션 gooddevelopmentpractices.1) theavallingandrollingbackdatabaSechanges.2) MigrationsEnsUreTeAmmebers'SchemasStaySynchronized.3) theencouroughoughoughdatabovase innandeasyre

Laravel의 Soft Deletion 기능은 실제 삭제보다는 레코드를 표시하여 데이터를 보호합니다. 1) SoftDeletEstrait 및 Deleted_at 필드를 모델에 추가하십시오. 2) delete () 메소드를 사용하여 삭제를 표시하고 복원 () 메소드를 사용하여 복원하십시오. 3) 쿼리시 소프트 삭제 레코드를 포함시키기 위해 withTrashed () 또는 coneseTrashed ()를 사용하십시오. 4) 성능을 최적화하기 위해 일정 시간을 초과 한 소프트 삭제 레코드를 정기적으로 청소하십시오.

laravelmigrationseversioncontrolfordatabaseSchemas.

laravelmigrationsmayfailtorollbackduetodataintegritysues, foreignkeyconstraints, orirreversibleactions.1) dataintegrityScanoccurifamigrationaddsdatathatcan'tBeontundone, likeacolumnwithadefaultValue.2) 외국 keycanstraintscanpreventrollsofrelatio


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

WebStorm Mac 버전
유용한 JavaScript 개발 도구