发布网友 发布时间:2024-10-03 16:06
共1个回答
热心网友 时间:2024-10-03 17:07
没有模型的框架是没有灵活的!每个框架都会针对数据库进行深度设计,以便快捷地进行SQL的增删改查,把重复的劳动抽象出来,提高应用开发效率。
本期就来讲讲laravel的模型初阶用法。
模型是在代码中抽象一层,把数据库操作提取出来。laravel支持常用的数据库产品,我们以MySQL为例。首先在配置文件内,配置参数对数据库连接。
在配置文件 config/database.php 内,默认的配置如下:包括数据库连接名,数据库地址,端口,用户名和密码,数据库名等等信息,就完成了初始化配置。一般,如果不手动指定,laravel模型内的$connection 就是取的配置文件内的这一行:也即是mysql数据库。
接着我们通过迁移功能,创建一个迁移文件。这样无需我们手动创建数据库表。在命令行运行以下指令:
命令行输出如下:
可以看到系统创建了一个模型文件在app/Event.php。其中内容视不同的laravel版本而有所不同,但是基础内容未变:有了模型对应数据库表,现在我们还缺一个数据库表,在迁移文件内进行配置。由于我们在上述命令行脚手架中使用了--migration 选项,系统就创建了迁移文件,编辑 2020_09_27_202416_create_events_table.php 内容。自带的内容如下:其中up 方法 Schema 用于创建数据库字段,索引等等,其中 down 方法,用于回滚迁移。在生命中,默认给了两个字段:我们为数据库表再增加一些字段:其中string 方法创建的是 VARCHAR 类型的字段,text 方法创建 TEXT 类型的字段。 nullable 方法表名该字段默认允许为 NULL。
完成表单的字段设计后,我们将设计的表应用到数据库。在命令行执行以下指令:命令行输出大致如下:其中users 表,password_resets 表,是系统自带的权限系统使用的。为了验证是否迁移成功,我们在命令行使用mysql客户端连接目标数据库。首先展示所有的表名:重点看一下我们设计的events 表的结构,是否如 Schema 的期望:如果我们需要重新设计表结构,对上面的迁移进行回滚也很简单,执行以下命令:输出内容如下:这可不妙,我们只想回滚events 表,不想回滚 user password_resets 表。那么我们需要手动指定,回滚的时候,仅回滚最新一批次的迁移。执行以下代码:输出如下:注意是按照批次回滚的,如果回滚到第二批次,第三批次,只用指定--step=N 即可。
本文讲解了laravel在连接数据库,创建数据库表迁移文件的内容。对于强大的Eloquent ORM 这只是一个开始。Happy coding :-)