怎么新建MySQL数据库

发布时间:2022-06-16 作者:admin
阅读:564
这篇文章给大家介绍了“新手怎么学习Laravel,有哪些基础知识要掌握”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了一些基础知识,包括了怎么安装Laravel、路由、验证器、视图等等相关内容,下面一起来看一下,希望对大家有帮助。

一、安装laravle

1、安装composer

2、执行命令:

composer create-project laravel/laravel 项目文件夹名 --prefer-dist

二、目录简介

  • app:应用程序的核心代码

  • bootstrap:一个引导框架的app.php文件,一个cache目录(包含路由及缓存文件),框架启动文件,一般情况不动。

  • config:所有配置文件

  • database:其中migrations目录可以生成数据表。

  • public:入口文件存放地,以及静态资源(和tp类似)

  • resources

  • routes:应用的所有路由定义

  • tests:可用来单元测试

  • vendor:所有composer依赖包

三、路由初识

1、常见的几种请求

  • Route::get( u r l , url, url,callback);
  • Route::post( u r l , url, url,callback);
  • Route::put( u r l , url, url,callback);
  • Route::delete( u r l , url, url,callback);

2、匹配指定的请求方式

Route::match(['get','post'],'/',function(){});

3、配置任意请求方式

Route::any('/home', function () {
    });

4、给路由加必填参数

Route::get('/home/{id}', function ($id) {
    echo 'id为:'.$id;});

5、给路由增加可选参数

Route::get('/home/{id?}', function ($id = '') {
    echo 'id为:'.$id;});

6、通过?形式传递get参数

Route::get('/home', function () {
    echo 'id为:'.$_GET['id'];});

7、给路由增加别名

Route::any('/home/index', function () {
    echo '测试';})->name('hh');

8、设置路由群组

例如有如下路由:

  • /admin/login
  • /admin/index
  • /admin/logout
  • /admin/add

如果一个一个添加是比较麻烦的,他们有一个共同的区别,都是有/admin/前缀,可设置一个路由群组进行添加:

Route::group(['prefix'=>'admin'], function () {
    Route::get('test1', function () {
        echo 'test1';
    });
    Route::get('test2', function () {
        echo 'test2';
    });});

此时就可通过/admin/test1来进行访问了。

9、路由配置控制器

控制器可以建一个前台和一个后台:

命令行创建路由:

php artisan make:controller Admin/IndexController

基本路由建立:

Route::get('test/index','TestController@index');

分目录路由建立:

Route::get('/admin/index/index','Admin\IndexController@index');

四、laravel验证器

引入:use Illuminate\Support\Facades\Validator

$param = $request->all();$rule = [
    'name'=>'required|max:2',];$message = [
    'required'  => ':attribute不能为空',
    'max' => ':attribute长度最大为2'];$replace = [
    'name' => '姓名',];$validator = Validator::make($param, $rule, $message,$replace);if ($validator->fails()){
    return response()->json(['status'=>0,'msg'=>$validator->errors()->first()]);}

五、控制器获取用户输入的值

在控制器中如果要使用一个类,例如use Illuminate\Http\Request,就可以简写为use Request
但是需要在config目录下的app.php配置文件中加入:

'aliases' => [

        'App' => Illuminate\Support\Facades\App::class,
        'Arr' => Illuminate\Support\Arr::class,
        'Artisan' => Illuminate\Support\Facades\Artisan::class,
        'Auth' => Illuminate\Support\Facades\Auth::class,
        'Blade' => Illuminate\Support\Facades\Blade::class,

        'Request' => Illuminate\Support\Facades\Request::class,

    ],

1、获取用户单个输入值:

Input::get('id')

2、获取用户输入的所有值:

Input::all()

打印出来的是数组

关于dd(dump+die)

3、获取用户输入指定的值:

Input::only(['id','name']  //只接收id,其余不接受

4、获取用户输入指定值之外的值:

Input::except(['name']    //不接收name,其余都接收

5、判断某个值是否存在

Input::has('name')    //存在返回true  不存在返回false  其中0返回true

六、视图的创建与使用

1、视图的创建

视图也可分目录管理:


控制器语法:

return view('home/test');

也可写为:

return view('home.test');

2、变量映射

控制器中:

return view('home/test',['day'=>time()]);

视图中:

{{$day}}

其中控制器中变量映射有三种:

  • view(模板文件,数组)
  • view(模板文件)->with(数组)
  • view(模板文件)->with(数组)->with(数组)

了解一下compact数组。

3、视图渲染

3.1 foreach的使用

控制器中:

public function index(){

        $arr = [
            0 => [
                'name' => 'tom',
                'age' => '12',
            ],
            1 => [
                'name' => 'bby',
                'age' => '13',
            ]
        ];
        return view('home/test',['data'=>$arr]);
    }

视图中:

@foreach($data as $k=>$v)
    键:{{$k}}
    值:{{$v['name']}}    <br/>@endforeach

3.2 if的使用

@if(1==2)
    是的
@else
    不是的
@endif

4、视图之间的引用

@include('welcome')

七、模型的创建与使用

1、创建模型的命令

php artisan make:model Model/Admin/Member

此时,就会在app目录内创建:

2、模型基本设置

<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Member extends Model{
    //定义表名
    protected $table = 'student';
    //定义主键
    protected $primaryKey = 'id';
    //定义禁止操作时间
    public $timestamps = false;
    //设置允许写入的字段
    protected $fillable = ['id','sname'];}

3、模型数据添加

方式一:

	 $model = new Member();
	 $model->sname = '勒布朗';
	 $res = $model->save();
	 dd($res);

方式二:

     $model = new Member();
     $res = $model->create($request->all());
     dd($res);

4、模型的表连接

//查询客户与销售顾问的客资列表$data = Custinfo::select(['custinfo.*', 'customers.name'])
    ->join('customers', 'customers.id', '=', 'custinfo.cust_id')
    ->where($where)
    ->get()
    ->toArray();

5、简单模型关联一对一

<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Phone extends Model{
    //定义表名
    protected $table = 'phone';

    //定义主键
    protected $primaryKey = 'id';

    //定义禁止操作时间
    public $timestamps = false;

    //设置允许写入的字段
    protected $fillable = ['id','uid','phone'];}
<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Member extends Model{
    //定义表名
    protected $table = 'student';

    //定义主键
    protected $primaryKey = 'id';

    //定义禁止操作时间
    public $timestamps = false;

    //设置允许写入的字段
    protected $fillable = ['id','sname'];

    /**
     * 获取与用户关联的电话号码记录。
     */
    public function getPhone()
    {
        return $this->hasOne('App\Model\Admin\Phone', 'uid', 'id');
    }}
    //对象转数组
    public function Arr($obj)
    {
        return json_decode(json_encode($obj), true);
    }


    public function index(){
        $infoObj = Member::with('getPhone')->get();
        $infoArr = $this->Arr($infoObj);
        print_r($infoArr);
    }


八、日志

1、自定义日志目录

config目录下的logging.php中的channels配置:

 'custom' => [
     'driver' => 'single',
     'path' => storage_path('logs/1laravel.log'),
     'level' => 'debug',
 ]

控制器中:

$message = ['joytom','rocker'];Log::channel('custom')->info($message);

九、迁移文件

建立一个迁移文件:php artisan make:migration create_shcool_table

会在database\migrations下创建一个文件:

在up方法中增加如下代码:

<?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illuminate\Support\Facades\Schema;class CreateShcoolTable extends Migration{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('shcool', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('school_name','20')->notNull()->unique();

            $table->tinyInteger('status')->default(1);

            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('shcool');
    }}

更详细的生成SQL方法请参考:数据迁移文件常用方法速查表

写好SQL文件以后,执行:php artisan migrate

将会生成数据表,其中操作日志将记录在这个表中:


php artisan migrate:rollback:回滚最后一次的迁移操作, 删除(回滚)之后会删除迁移记录,并且数据表也会删除,但是迁移文件依旧存在,方便后期继续迁移(创建数据表)。


以上就是关于“新手怎么学习Laravel,有哪些基础知识要掌握”的介绍了,感谢各位的阅读,如果大家想要了解更多相关的内容,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145