
现在,让我们一行行分析结构生成器生成的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_tablephp文件,添加电子邮件列。我们使用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命令还有一个更强大的命令行,它可以回滚所有的迁移:
laravel ORM支持多数据库,但mongodb需要用插件:jenssegers/laravel-mongodb · GitHub
1、表名问题不大,关键是你的表是适合MVC结构的,spring应该差不多,要玩转laravel,还是要使用Eloquent ORM,这样你需要给你的表建立对应的entity(也就是model),然后通过model建立好表间关系。另外有个插件可以 从现有的表 直接生成 migration,你可以试试。
2、数据库事件 主要通过模型事件来完成:
Project::creating(function($project) { }); //
Project::created(function($project) { });
Project::updating(function($project) { }); //
Project::updated(function($project) { });
Project::saving(function($project) { }); //
Project::saved(function($project) { });
Project::deleting(function($project) { }); //
Project::deleted(function($project) { });
还是比较简单的
检索表中的所有行
复制代码
代码如下:
$users =
DB::table('users')->get();
foreach ($users as
$user)
{
var_dump($user->name);
}
从表检索单个行
复制代码
代码如下:
$user =
DB::table('users')->where('name',
'John')->first();
var_dump($user->name);
laravel 单数据库的话没有要两个地方配置吧 正常就是env里配置就好了 其他的地方只是调用这个配置其他地方的配置是默认好的,是争对不同数据库系统做的配置,一般来说不需要管它。
OQL是我设计用来处理PDFNET开发框架的ORM查询的,因此叫做ORM查询语言。自2006年第一版以来,经历了多次重构,到PDFNET Ver 4X 版本,已经比较稳定了,在我做的项目和框架用户朋友的项目中得到成功应用,基本符合一般的常规应用需求。
OQL有下面3个显著特点:
抽象的SQL,屏蔽了具体数据库的差异,因此支持所有数据库;
对象化的“SQL”,写OQL代码能够获得IDE的智能提示,能够得到编译时检查确保不会写出错误的SQL;
没有使用NET的特性,比如泛型、反射、表达式树等东西,因此理论上OQL可以跨语言平台,比如移植到Java,C++,VB等。
OQL的原理基于2大特性:
表达式的链式调用
属性的实例调用
OQL支持4大类数据 *** 作
数据查询:
单实体类(单表)查询
多实体类(多表)关联查询
数据修改
更新数据
删除数据
统计、聚合运算
OQL分页
以上就是关于laravel 怎么设置数据库端口全部的内容,包括:laravel 怎么设置数据库端口、Laravel如何使用数据库事务及捕获事务失败、laravel 5 增加数据的时候多个字段,attributes如何使用等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)