目次
Laravel 5框架学习之Eloquent (laravel 的ORM),laraveleloquent
ホームページ php教程 php手册 Laravel 5框架学习之Eloquent (laravel 的ORM),laraveleloquent

Laravel 5框架学习之Eloquent (laravel 的ORM),laraveleloquent

Jun 13, 2016 am 09:07 AM
eloquent laravel orm

Laravel 5框架学习之Eloquent (laravel 的ORM),laraveleloquent

我们来生成第一个模型

复制代码 代码如下:
php artisan make:model Article
#输出
Model created successfully.
Created Migration: 2015_03_28_062517_create_articles_table

查看一下生成的文件 app/Article.php

1

2

3

4

5

6

7

8

9

<&#63;php namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class Article extends Model {

 

 //

 

}

ログイン後にコピー

没什么特别的,除了继承自 Model 以外,但是具有强大的功能,这些都封装在laravel的Model中。模型自动具有了 save() update() findXXX() 等强大的功能。

tinker 是 laravel提供的命令行工具,可以和项目进行交互。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

php artisan tinker

 

#以下是在tinker中的交互输入

Psy Shell v0.4.1 (PHP 5.4.16 — cli) by Justin Hileman

>>> $name = 'zhang jinglin';

=> "zhang jinglin"

 

>>> $name

=> "zhang jinglin"

 

>>> $article = new App\Article;

=> <App\Article #000000005c4b7ee400000000ab91a676> {}

 

>>> $article->title = 'My First Article';

=> "My First Article"

 

>>> $article->body = 'Some content...';

=> "Some content..."

 

>>> $article->published_at = Carbon\Carbon::now();

=> <Carbon\Carbon #000000005c4b7ee600000000ab91dcb6> {

    date: "2015-03-28 06:37:22",

    timezone_type: 3,

    timezone: "UTC"

  }

 

>>> $article;

=> <App\Article #000000005c4b7ee400000000ab91a676> {

    title: "My First Article",

    body: "Some content...",

    published_at: <Carbon\Carbon #000000005c4b7ee600000000ab91dcb6> {

      date: "2015-03-28 06:37:22",

      timezone_type: 3,

      timezone: "UTC"

    }

  }

 

>>> $article->toArray();

=> [

    "title"    => "My First Article",

    "body"     => "Some content...",

    "published_at" => <Carbon\Carbon #000000005c4b7ee600000000ab91dcb6> {

      date: "2015-03-28 06:37:22",

      timezone_type: 3,

      timezone: "UTC"

    }

  ]

 

>>> $article->save();

=> true

 

#查看数据结果,添加了一条记录

 

>>> App\Article::all()->toArray();

=> [

    [

      "id"      => "1",

      "title"    => "My First Article",

      "body"     => "Some content...",

      "published_at" => "2015-03-28 06:37:22",

      "created_at"  => "2015-03-28 06:38:53",

      "updated_at"  => "2015-03-28 06:38:53"

    ]

  ]

 

>>> $article->title = 'My First Update Title';

=> "My First Update Title"

 

>>> $article->save();

=> true

 

>>> App\Article::all()->toArray();

=> [

    [

      "id"      => "1",

      "title"    => "My First Update Title",

      "body"     => "Some content...",

      "published_at" => "2015-03-28 06:37:22",

      "created_at"  => "2015-03-28 06:38:53",

      "updated_at"  => "2015-03-28 06:42:03"

    ]

  ]

   

>>> $article = App\Article::find(1);

=> <App\Article #000000005c4b7e1600000000ab91a676> {

    id: "1",

    title: "My First Update Title",

    body: "Some content...",

    published_at: "2015-03-28 06:37:22",

    created_at: "2015-03-28 06:38:53",

    updated_at: "2015-03-28 06:42:03"

  }

 

>>> $article = App\Article::where('body', 'Some content...')->get();

=> <Illuminate\Database\Eloquent\Collection #000000005c4b7e1800000000ab91a676> [

    <App\Article #000000005c4b7e1b00000000ab91a676> {

      id: "1",

      title: "My First Update Title",

      body: "Some content...",

      published_at: "2015-03-28 06:37:22",

      created_at: "2015-03-28 06:38:53",

      updated_at: "2015-03-28 06:42:03"

    }

  ]

 

>>> $article = App\Article::where('body', 'Some content...')->first();

=> <App\Article #000000005c4b7e1900000000ab91a676> {

    id: "1",

    title: "My First Update Title",

    body: "Some content...",

    published_at: "2015-03-28 06:37:22",

    created_at: "2015-03-28 06:38:53",

    updated_at: "2015-03-28 06:42:03"

  }

>>>

 

>>> $article = App\Article::create(['title' => 'New Article', 'body' => 'New body', 'published_at' => Carbon\Carbon::now()]);

Illuminate\Database\Eloquent\MassAssignmentException with message 'title'

ログイン後にコピー

MassAssignmentException,laravel保护我们不能直接插入记录。比如,在一些特殊情况下我们需要直接利用表单的信息填充数据库记录,但是如果我们并没有在表单中添加密码字段,而黑客产生了密码字段连同我们的其他字段一起送回服务器,这将产生修改密码的危险,所以我们必须明确的告诉laravel我们的模型那些字段是可以直接填充的。

修改我们的模型文件 Article.php

1

2

3

4

5

6

7

8

9

10

11

12

13

<&#63;php namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class Article extends Model {

 

 protected $fillable = [

    'title',

    'body',

    'published_at'

  ];

 

}

ログイン後にコピー

表示,title, body, published_at 是可以直接填充的。

退出 tinker,重新进入

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

>>> $article = App\Article::create(['title' => 'New Article', 'body' => 'New body', 'published_at' => Carbon\Carbon::now()]);

=> <App\Article #000000005051b2c7000000007ec432dd> {

    title: "New Article",

    body: "New body",

    published_at: <Carbon\Carbon #000000005051b2c6000000007ec4081d> {

      date: "2015-03-28 06:55:19",

      timezone_type: 3,

      timezone: "UTC"

    },

    updated_at: "2015-03-28 06:55:19",

    created_at: "2015-03-28 06:55:19",

    id: 2

  }

   

# It's ok

 

>>> App\Article::all()->toArray();

=> [

    [

      "id"      => "1",

      "title"    => "My First Update Title",

      "body"     => "Some content...",

      "published_at" => "2015-03-28 06:37:22",

      "created_at"  => "2015-03-28 06:38:53",

      "updated_at"  => "2015-03-28 06:42:03"

    ],

    [

      "id"      => "2",

      "title"    => "New Article",

      "body"     => "New body",

      "published_at" => "2015-03-28 06:55:19",

      "created_at"  => "2015-03-28 06:55:19",

      "updated_at"  => "2015-03-28 06:55:19"

    ]

  ]

 

>>> $article = App\Article::find(2);

=> <App\Article #000000005051b22b000000007ec432dd> {

    id: "2",

    title: "New Article",

    body: "New body",

    published_at: "2015-03-28 06:55:19",

    created_at: "2015-03-28 06:55:19",

    updated_at: "2015-03-28 06:55:19"

  }

 

>>> $article->update(['body' => 'New Updaet Body']);

=> true

 

#update自动调用save()

ログイン後にコピー

以上所述就是本文的全部内容了,希望能够对大家学习Laravel5框架有所帮助。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP vs. Flutter: モバイル開発に最適な選択 PHP vs. Flutter: モバイル開発に最適な選択 May 06, 2024 pm 10:45 PM

PHP vs. Flutter: モバイル開発に最適な選択

Laravel - アーティザンコマンド Laravel - アーティザンコマンド Aug 27, 2024 am 10:51 AM

Laravel - アーティザンコマンド

PHP でオブジェクト リレーショナル マッピング (ORM) を使用してデータベース操作を簡素化するにはどうすればよいですか? PHP でオブジェクト リレーショナル マッピング (ORM) を使用してデータベース操作を簡素化するにはどうすればよいですか? May 07, 2024 am 08:39 AM

PHP でオブジェクト リレーショナル マッピング (ORM) を使用してデータベース操作を簡素化するにはどうすればよいですか?

PHP単体テストツールの長所と短所の分析 PHP単体テストツールの長所と短所の分析 May 06, 2024 pm 10:51 PM

PHP単体テストツールの長所と短所の分析

Laravel と CodeIgniter の最新バージョンの比較 Laravel と CodeIgniter の最新バージョンの比較 Jun 05, 2024 pm 05:29 PM

Laravel と CodeIgniter の最新バージョンの比較

Laravel と CodeIgniter のデータ処理機能はどのように比較されますか? Laravel と CodeIgniter のデータ処理機能はどのように比較されますか? Jun 01, 2024 pm 01:34 PM

Laravel と CodeIgniter のデータ処理機能はどのように比較されますか?

PHPコードの単体テストと統合テスト PHPコードの単体テストと統合テスト May 07, 2024 am 08:00 AM

PHPコードの単体テストと統合テスト

Laravel と CodeIgniter: 大規模プロジェクトにはどちらのフレームワークが適していますか? Laravel と CodeIgniter: 大規模プロジェクトにはどちらのフレームワークが適していますか? Jun 04, 2024 am 09:09 AM

Laravel と CodeIgniter: 大規模プロジェクトにはどちらのフレームワークが適していますか?

See all articles