侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Laravel实现数据库迁移与支持中文的填充

Laravel  /  管理员 发布于 8年前   158

前言

数据库迁移实际上就是对数据库库表的结构变化做版本控制,之前对数据库库表结构做修改的方式比较原始,比如说对某张库表新增了一个字段,都是直接在库表中执行alter table xxx add .. 的方式直接修改,但是这么做有些弊端,比如在开发阶段,你自己的库表修改了,还要把这句sql语句传给别人再执行一遍,这在多人协同开发时不是一种好的方式.那有没有一种方式能让我们对数据库 库表的修改做一些简单的版本控制,同时能让其他人很方便的同步我们对数据库的修改呢?

答案是我们可以使用Laravel 内置的Migrations .

对数据库的管理包括哪些部分?

其实Laravel对数据库的版本管理主要包括两部门: 数据库结构的管理 和数据的管理.

  • 数据库结构的管理: 主要是对数据库结构进行管理,比如新增了一张表,某张表增加了一个字段等等.
  • 数据的管理: 这个主要是管理表中的数据,生成一些填充数据,解决我们开发调试时没有测试数据的问题.

经常我们做项目都团队协作开发,每个人都在自己本地的数据库,如果你曾经出现过让同事手动在数据库结构中添加字段的情况,数据库迁移可以解决你这个问题。

不仅如此,在线上部署的时候,也避免了手动导入数据库或手动修改数据结构的麻烦,数据迁移帮你方便的维护着数据结构。

数据填充,让我们测试的时候需要大量的假数据不再一条一条的去造数据,可以轻松的批量填充大量数据。

本文基于Laravel5.5,其他版本大同小异。

数据迁移

假如我们需要一张学生表,我们不再使用原生SQl语句去创建表。

创建迁移文件

前提是已经配置好了数据库连接信息

php artisan make:migration create_students_table

此命令会在database/migrations/目录生成类似2017_10_28_035802_create_students_table.php的文件

我们在里边添加students表的数据结构

engine = 'InnoDB';  // id自增  $table->increments('id');  // 学生名称  $table->string('name');  // 性别  $table->string('sex');  // 邮箱  $table->string('email');  // 喜爱的颜色  $table->string('favorite_color');  // 手机号  $table->string('phone');  // 地址  $table->string('addr');  // 自动维护时间戳  $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('students'); }}

更多用法,请参考官方手册。

运行迁移

php artisan migrate

这样会运行database/migrations/目录的所有迁移文件,并自动创建migrations表,来记录已经运行过的迁移文件,防止重复运行。

我们看一下数据库是不是自动创建了students表了呢。

如果出现以下错误:

[Illuminate\Database\QueryException]SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table users add unique users_email_unique(email))[PDOException]SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes

在database/migrations/目录里会有laravel自带的用户和重置密码的两个迁移文件,会一并运行。
在这里我们这样解决,修改数据库配置文件config/database.php里的mysql下的字符集为utf8即可

'charset' => 'utf8','collation' => 'utf8_unicode_ci',

想知道为什么,可猛戳:127319.htm

数据填充(支持中文)

创建学生表Eloquent模型

在app目录下创建Student.php

创建填充文件

php artisan make:seed StudentsTableSeeder

这条命令会在database/seeds/目录下生成StudentsTableSeeder.php填充文件

create(); }}

调用该 Seeders

我们打开database/seeds/DatabaseSeeder.php文件,修改为

call(StudentsTableSeeder::class); }}

创建 模型工厂 填充

php artisan make:factory StudentsFactory -m Student

此命令会在database/factories/目录下生成StudentsFactory.php文件,我们定义一下要填充的数据格式

define(App\Student::class, function (Faker $faker) { $sex = rand(1, 1000); return [ 'name'  => $faker->name, 'sex'  => $sex % 2 == 0 ? '男' : '女', 'email'  => $faker->unique()->safeEmail, 'favorite_color' => $faker->safeColorName, 'phone'  => $faker->phoneNumber, 'addr'  => $faker->address, ];});

更多配置请查阅 vendor/fzaninotto/faker/src/Faker/Generator.php文件

让faker填充中文

 public function boot() { // 填充中文数据 $this->app->singleton(\Faker\Generator::class, function () {  return \Faker\Factory::create('zh_CN'); }); }

开始填充

首先我们执行一下:

composer dump-autoload

自动加载一下我们在database/seeds/目录创建的填充文件,以避免出现以下错误:

[ReflectionException]Class StudentsTableSeeder does not exist

接着我们运行填充命令:

php artisan db:seed

由于我们填充的是一万条数据,可以时间稍长,可以刷新数据库看着逐条增加的数据。

大功告成

如果以上操作都没有报错的话,来看一下我们的数据库表students表是否有数据了呢?

id name sex email favorite_color phone addr created_at updated_at
10000 谈英 男 [email protected] 白色 17642207316 贵阳海陵区 2017-10-28 05:19:10 2017-10-28 05:19:10
9999 汤淑珍 男 [email protected] 黑色 18239453935 南宁友好区 2017-10-28 05:19:10 2017-10-28 05:19:10
9998 贾春梅 男 [email protected] 粟色 17103645128 长沙萧山区 2017-10-28 05:19:10 2017-10-28 05:19:10
9997 季志明 男 [email protected] 灰色 17002359608 天津花溪区 2017-10-28 05:19:10 2017-10-28 05:19:10
9996 成燕 男 [email protected] 黄色 17181193397 贵阳锡山区 2017-10-28 05:19: 10 2017-10-28 05:19:10
9995 米博 男 [email protected] 紫 17187328893 广州东丽区 2017-10-28 05:19:10 2017-10-28 05:19:10
9994 兰淑兰 女 [email protected] 绿色 18592254358 兰州经济开发新区 2017-10-28 05:19:10 2017-10-28 05:19:10
9993 乐瑶 女 [email protected] 藏青 15891490007 香港龙潭区 2017-10-28 05:19: 10 2017-10-28 05:19:10
9992 叶志新 女 [email protected] 藏青 15564391466 北京高明区 2017-10-28 05:19:10 2017-10-28 05:19:10
9991 胥杨 男 [email protected] 黄色 17097722096 郑州新城区 2017-10-28 05:19:10 2017-10-28 05:19:10
9990 凌敏 女 [email protected] 鲜绿色 13021578051 杭州涪城区 2017-10-28 05:19:10 2017-10-28 05:19:10
9989 席建 女 [email protected] 紫 18070573726 南昌海陵区 2017-10-28 05:19:10 2017-10-28 05:19:10
9988 聂新华 女 [email protected] 水色 17004061646 成都南长区 2017-10-28 05:19:10 2017-10-28 05:19:10

……

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家的支持。

您可能感兴趣的文章:

  • Laravel框架数据库CURD操作、连贯操作总结
  • PHP开发框架Laravel数据库操作方法总结
  • Laravel5.7 数据库操作迁移的实现方法
  • Laravel框架实现多数据库连接操作详解
  • Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
  • PHP的Laravel框架结合MySQL与Redis数据库的使用部署
  • Laravel如何使用数据库事务及捕获事务失败后的异常详解
  • Laravel创建数据库表结构的例子
  • Laravel如何同时连接多个数据库详解
  • laravel框架数据库配置及操作数据库示例


  • 上一条:
    使用 laravel sms 构建短信验证码发送校验功能
    下一条:
    Laravel 5.4中migrate报错: Specified key was too long error的解决
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
    • Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
    • Laravel的轻量型购物车扩展包:binafy/laravel-cart(0个评论)
    • Laravel 11.11版本发布 - 查看模型中的第三方关系:show(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客