laravel5.2 使用update更新数据,为什么created

 我来答
rr...n@163.com
2017-10-28 · 超过20用户采纳过TA的回答
知道答主
回答量:78
采纳率:45%
帮助的人:26.2万
展开全部
现让我行行析结构器authors表面up()代码:

1 // auto increment id (primary key)
2 $table->increments('id');
3
4 $table->string('name');
5 $table->integer('age')->nullable();
6 $table->boolean('active')->default(1);
7 $table->integer('role_id')->unsigned();
8 $table->text('bio');
9
10 // created_at, updated_at DATETIME
11 $table->timestamps();

实际SQL代码:

1 `id` INT(11) NOT NULL AUTO_INCREMENT,
2 `name` VARCHAR(255) NOT NULL,
3 `age` INT(11) NULL DEFAULT NULL,
4 `active` TINYINT(4) NOT NULL DEFAULT '1',
5 `role_id` INT(10) UNSIGNED NOT NULL,
6 `bio` TEXT NOT NULL,
7
8 `created_at` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
9 `updated_at` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',

我意识迁移强我自需要记住些结构器写晦涩难懂SQL DDL代码
我创建表我想要滚候办呢需要于up()应down()使用drop()即
1 public function down()
2 {
3 Schema::drop('authors');
4 }

非简单行全部作用删除authors表熟悉sql等同于DROP TABLE authors
现我已经写架构我数据库执行迁移文件转命令行工具跳转应用目录运行artisan migrate命令:
1 php artisan migrate

执行结:

检查数据库发现已经authors表

表结构:

要使用sql语句实现张表sql查询语句:

1 CREATE TABLE `authors` (
2 id int AUTO_INCREMENT NOT NULL,
3 name varchar(255) NOT NULL,
4 age int,
5 active tinyint NOT NULL DEFAULT '1',
6 role_id int(10) UNSIGNED NOT NULL,
7 bio text NOT NULL,
8 created_at timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
9 updated_at timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
10 email varchar(64) NOT NULL,
11 /* Keys */
12 PRIMARY KEY (id)
13 ) ENGINE = InnoDB;

现假设我执行存错误想要滚我自需要使用artisan命令行工具执行面命令即:想修改数据模型创建新迁移再执行命令artisan migrate每执行artisan migrate命令都根据间戳检查哪些没执行执行跳文件没执行执行迁移直执行完所迁移文件
1 php artisan migrate:rollback

运行:

发现表authors已经数据库删除
现重新创建authors表执行artisan migrate命令:
1 php artisan migrate

表authors重新创建
我想表添加email列先使用artisan创建新迁移文件:
php artisan migrate:make add_email_to_authors_table

运行结:

编辑2014_03_12_051119_add_email_to_authors_table.php文件添加电邮件列我使用Schema::table()两参数:表名、闭包函数(函数内添加字段)
1 public function up()
2 {
3 Schema::table('authors', function($table) {
4 $table ->string('email', 64);
5 });
6 }

添加需要添加滚再使用Schema::table()
1 public function down()
2 {
3 Schema::table('authors', function($table) {
4 $table ->dropColumn('email');
5 });
6 }

面使用dropColumn()列
现运行artisan命令运行该迁移文件:

刷新数据库表发现email字段已经authors现图:

我滚迁移email字段表删除
Artisan命令更强命令行滚所迁移:
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式