πŸ₯•
TIL
  • [TIL] Studying tech / computer science knowledge
  • KeyMap
  • μ•Œκ³ λ¦¬μ¦˜
    • λ³΅μž‘λ„ 계산 ( Computational Complexity )
    • DisjointSet-unionFind
    • Bellman-ford Algorithm
    • Dijkstra's Algorithm
    • DP ( Dynamic Programming , 동적 κ³„νšλ²• )
    • ν”Œλ‘œμ΄λ“œ-μ›Œμ…œ μ•Œκ³ λ¦¬μ¦˜ (Floyd-Warshall algorithm)
    • Kruskal's Algorithm
    • 졜μž₯ 증가 μˆ˜μ—΄ (Longes Increasing Subsequence)
    • Prim's Algorithm
    • μ •λ ¬
    • μ‹œκ°„λ³΅μž‘λ„ 와 κ³΅κ°„λ³΅μž‘λ„ ( Time Complexity & Space Complexity )
    • Topological Sort (μœ„μƒ μ •λ ¬)
  • μ±… μ½κ³ λ‚œ ν›„ μš”μ•½
    • ν”„λ‘œκ·Έλž˜λ° λŒ€νšŒμ—μ„œ λ°°μš°λŠ” μ•Œκ³ λ¦¬μ¦˜ λ¬Έμ œν•΄κ²° μ „λž΅
    • cleancode
    • 도메인 주도 μ„€κ³„λ‘œ μ‹œμž‘ν•˜λŠ” λ§ˆμ΄ν¬λ‘œμ„œλΉ„μŠ€ 개발
    • 였브젝트
  • CDC
    • debzium
    • kafka
  • 개발 상식
    • asciidoctor
    • 컴파일러
    • ELK μŠ€νƒ
    • μ—”λ””μ•ˆ
    • git
    • Gitmoji
    • ν…ŒμŠ€νŠΈ μ’…λ₯˜
    • λΌμ΄λΈŒλŸ¬λ¦¬μ™€ ν”„λ ˆμž„μ›Œν¬
    • μ •κ·œ ν‘œν˜„μ‹
    • REST API
    • 동기와 비동기 / Blockingκ³Ό NonBlocking
    • Transaction Script와 Domain Model
    • λ””μžμΈ νŒ¨ν„΄
      • 행동 νŒ¨ν„΄
      • 객체 생성 νŒ¨ν„΄
        • 좔상 νŒ©ν† λ¦¬ νŒ¨ν„΄
        • λΉŒλ” νŒ¨ν„΄
        • νŒ©ν† λ¦¬ λ©”μ„œλ“œ νŒ¨ν„΄
        • [생성 νŒ¨ν„΄] ν”„λ‘œν†  νƒ€μž… (Prototype Parttern)
        • 싱글톀
      • ꡬ쑰 νŒ¨ν„΄
        • μ–΄λŒ‘ν„° νŒ¨ν„΄
        • λΈŒλ¦Ώμ§€ νŒ¨ν„΄
        • 컴포짓(Composite) νŒ¨ν„΄
        • λ°μ½”λ ˆμ΄ν„°
        • ν”„λ‘μ‹œ
    • refactoring
      • 쀑볡 μ½”λ“œ
      • μ „μ—­ 데이터
      • κΈ΄ ν•¨μˆ˜
      • κΈ΄ λ§€κ°œλ³€μˆ˜ λͺ©λ‘
      • κ°€λ³€ 데이터
      • μ΄ν•΄ν•˜κΈ° νž˜λ“  이름
  • 자료ꡬ쑰
    • AVL Tree
    • Splay Tree
    • aaTree
    • array-list
    • 자료ꡬ쑰 μ‹œκ°„/곡간 λ³΅μž‘λ„
    • κ·Έλž˜ν”„
    • νž™
    • Red Black Tree
    • stack-queue
    • 트리 ( Tree )
  • DevOps
    • MSA
    • Kubernetes
      • AccessingAPI
      • controller
      • dashboard
      • kubernetes
      • object
      • pod
      • service
      • volume
  • Java
    • μ–΄λ…Έν…Œμ΄μ…˜
    • μ œμ–΄λ¬Έ
    • 데이터 νƒ€μž…
    • Enum
    • jvm
    • μ—°μ‚°μž
    • thread
    • Java8
      • CompletableFuture
      • Date/Time
      • μ–΄λ…Έν…Œμ΄μ…˜κ³Ό λ©”νƒ€μŠ€νŽ˜μ΄μŠ€
      • μΈν„°νŽ˜μ΄μŠ€
      • λžŒλ‹€μ‹
      • Optional
      • 슀트림
  • JavaScript
    • moduleProject
    • webpack-babel
    • μ½”μ–΄ μžλ°”μŠ€ν¬λ¦½νŠΈ
      • array
      • ν•¨μˆ˜ 바인딩
      • λ°μ½”λ ˆμ΄ν„°μ™€ ν¬μ›Œλ”©
      • Class
      • 비ꡐ μ—°μ‚°μž
      • Date λ‚΄μž₯ 객체
      • destructuring-assignment
      • function
      • ν•¨μˆ˜μ˜ prototype ν”„λ‘œνΌν‹°
      • κ°€λΉ„μ§€ μ»¬λ ‰μ…˜ ( Garbage Collection )
      • JSON (JavaScript Object Notation)
      • map-set
      • λ‚΄μž₯ ν”„λ‘œν† νƒ€μž…
      • newμ—°μ‚°μžμ™€ μƒμ„±μž ν•¨μˆ˜
      • 객체
      • Object.keys, values, entries
      • μ˜΅μ…”λ„ 체이닝 '?.'
      • ν”„λ‘œνΌν‹° ν”Œλž˜κ·Έ
      • ν”„λ‘œνΌν‹° μ’…λ₯˜
      • ν”„λ‘œν†  νƒ€μž…
      • 호좜 μŠ€μΌ€μ€„λ§ ( scheduling a call )
      • scope
      • this
      • type-conversions
      • type
      • ν•¨μˆ˜μ˜ μžλ£Œν˜•
      • var_let_const
  • Linux
    • κΈ°λ³Έ λͺ…λ Ήμ–΄
    • 파일 μ’…λ₯˜
    • λ¦¬λˆ…μŠ€
  • λ„€νŠΈμ›Œν¬
    • μ‘μš© 계측 ( Application Layer )
    • 였λ₯˜ κ²€μΆœκ³Ό 였λ₯˜ μ •μ •
    • Http
    • Http Header
    • 컴퓨터 λ„€νŠΈμ›Œν¬λž€
    • λ„€νŠΈμ›Œν¬ 계측
    • λ„€νŠΈμ›Œν¬ μ œμ–΄ μ˜μ—­
    • 전솑 계측 ( Transport Layer )
  • PHP
    • Facade
    • composer
    • scopeResolutionOperator
    • Laravel
      • SocialProvider
      • architecture
      • blade
      • controller
      • db
      • dbArchitecture
      • debug
      • eloquent
      • email
      • event
      • exceptionHandling
      • middleware
      • model
      • modelFactory
      • pagingLoading
      • queryBuilder
      • route
      • scout
      • seeding
      • tntsearch
      • validate
      • view
  • React
    • Next.js
    • React λž€?
  • Spring
    • Controller
    • μš”μ²­μ΄ λ“€μ–΄μ™”μ„λ•Œ μŠ€ν”„λ§μ΄ μ²˜λ¦¬ν•˜λŠ” 방법 ( 내뢀ꡬ쑰 )
    • ConfigurationProperties
    • Entity / DTO / VO
    • Maven
    • Repository와 DAO
    • μŠ€ν”„λ§ 빈
    • Spring Framework
    • MVC νŒ¨ν„΄
    • 도메인 μž…λ ₯κ°’ 검증
    • Spring Cloud
      • Spring Cloud
      • Eureka
    • Spring Data
      • JPA
      • JPA μ–΄λ…Έν…Œμ΄μ…˜
      • μ—”ν‹°ν‹° 비ꡐ
      • 볡합 킀와 식별 관계 λ§€ν•‘
      • JPA μ˜ˆμ™Έμ²˜λ¦¬
      • 객체지ν–₯ 쿼리
      • EntityManagerFactory와 EntityManager
      • JPA μ΅œμ ν™”
      • ν”„λ‘μ‹œμ™€ 연관관계 λ§΅ν•‘
      • 연관관계
      • 상속관계 λ§΅ν•‘
      • νŠΈλžœμž­μ…˜ λ²”μœ„μ™€ μ˜μ†μ„± μ»¨ν…μŠ€νŠΈ
      • 데이터 νƒ€μž…
      • MySQL μ—°κ²°
      • Pageable
    • Spring Projectλ“€κ³Ό library
      • Custom Serialize
      • Elasticsearch Index API
      • Spring HATEOAS
      • lombok (둬볡)
      • Model Mapper
      • Object Mapper
      • Representation Model
      • Spring REST Docs
      • Spring Boot
    • Spring Security
      • Spring Security
      • Authentication
      • Authentication Filter
      • Authorization Filter
      • Filter Chain
      • SecurityContext
      • Spring OAuth2.0
    • Spring Test
      • AssertJ
      • Junit5
      • JunitParams
      • Mock Object
  • DataBase
    • ALIAS
    • CONCAT
    • CTE
    • Group By
    • HAVING
    • IFNULL
    • 인덱슀
    • JOIN
    • ORDER BY
    • ROLLUP
    • SELECT
    • SELECT DISTINCT
    • SQL
    • WHERE
  • Web 상식
    • OAuth
    • WAS
    • HTTP톡신 기반 인증
    • λΈŒλΌμš°μ €
    • CSR κ³Ό SSR
    • HTTPS
    • Web
Powered by GitBook
On this page
  1. PHP
  2. Laravel

seeding

db ν…Œμ΄λΈ”μ— 데이터λ₯Ό μ‹¬λŠ” ν–‰μœ„λ₯Ό μ‹œλ”©μ΄λΌκ³  ν•˜κ³  μ΄λŠ” μ„œλΉ„μŠ€ ꡬ성에 ν•„μš”ν•œ κΈ°λ³Έ 데이터, 개발 쀑에 ν•„μš”ν•œ 데이터, ν…ŒμŠ€νŠΈλ₯Ό μœ„ν•œ 데이터λ₯Ό 빨게 μ€€λΉ„ν•  λ•Œ μ‚¬μš©ν•œλ‹€.

라라벨은 클래슀 λ¬Έλ²•μœΌλ‘œ 데이터 μ‹œλ”©μ„ μžλ™ν™”ν•  수 μžˆλŠ” 방법을 μ œκ³΅ν•˜κ³  μžˆλ‹€.

$ php artisan make:seeder UsersTableSeeder

μœ„ λͺ…λ Ήμ–΄λ₯Ό 치면 database/seeds ν•˜μœ„μ— 생성이 되고 클래슀 이름은 자유둭게 μ§€μœΌλ©΄ λœλ‹€. 클래슀 λ‚΄λΆ€μ˜ run()λ©”μ„œλ“œλ₯Ό μ΄μš©ν•΄ μ‹œλ”©μ΄ 이루어지기 λ•Œλ¬Έμ— μ‹œλ”© λ‘œμ§μ„ λ„£μ–΄μ£Όλ©΄ λœλ‹€.

class UsersTableSeeder extends Seeder
{
    public function run()
    {
        App\User::create([
            'name'=> sprintf('%s %s',str_random(3), str_random(4)),
            'email' => str_random(10) . '@example.com',
            'password' => bcrypt('password'),
        ]);
    }
}

λ§ˆμŠ€ν„° μ‹œλ”

λͺ¨λΈλ§ˆλ‹€ μ•„ν‹°μ¦Œ μ‹œλ”© λͺ…령을 μˆ˜ν–‰ν•˜λŠ” 것은 번거둭기 λ•Œλ¬Έμ— μ‹œλ” 클래슀λ₯Ό ν•œλ²ˆμ— 등둝할 수 μžˆλŠ” λ§ˆμŠ€ν„° μ‹œλ” 클래슀λ₯Ό μ‚¬μš©ν•˜λŠ” 것이 νŽΈν•˜κ³  이λ₯Ό μ΄μš©ν•΄μ„œ μˆ˜ν–‰ν•΄μ•Ό ν•˜λŠ” μ΄μœ λŠ” μ‹œλ”©μ˜ μˆœμ„œλ•Œλ¬Έμ΄λ‹€. 각 ν…Œμ΄λΈ”κ°„μ˜ 연관관계가 μ—†λ‹€λ©΄ λͺ¨λ₯΄κ² μ§€λ§Œ μ‘΄μž¬ν•œλ‹€λ©΄ μ‹œλ”©ν•˜λŠ” μˆœμ„œλ„ μ€‘μš”ν•˜κΈ° λ•Œλ¬Έμ΄λ‹€. (μ—†λŠ” μ»¬λŸΌμ— μ’…μ†λœ μ»¬λŸΌμ€ μ‚½μž…μ΄ λΆˆκ°€λŠ₯ν•˜κΈ° λ•Œλ¬Έμ—)

class DatabaseSeeder extends Seeder{
    public function run(){
        if(config('database.default') !== 'sqlite'){
            DB::statement('SET FOREIGN_KEY_CHECKS=0');
        }

        //Model::unguard();

        App\User::truncate();
        $this->call(UsersTableSeeder::class);

        App\Article::truncate();
        $this->call(ArticlesTableSeeder::class);

        //Model::reguard();

        if(config('database.default') !== 'sqlite'){
            DB::statement('SET FOREIGN_KEY_CHECKS=1');
        }
    }
}

Model::unguard()와 Model::reguard() λ©”μ„œλ“œλŠ” μ—˜λ‘œν€€νŠΈ λͺ¨λΈμ— μ •μ˜ν•œ λŒ€λŸ‰ ν• λ‹Ή μ œμ•½ 사항을 ν’€μ—ˆλ‹€κ°€ μž κ·ΈλŠ” λͺ…λ ΉμœΌλ‘œ 라라벨5.2이상은 μ‹œλ”©ν•  λ•Œ μžλ™μœΌλ‘œ ν’€κ³  μž κ·Όλ‹€.

  • config('database.default') : config/database.phpνŒŒμΌμ—μ„œ default킀에 ν• λ‹Ήλœ 값을 μ½μ–΄μ˜€λŠ” ꡬ문으둜 dbμ’…λ₯˜κ°€ λ°˜ν™˜λœλ‹€. sqliteλŠ” μ™ΈλΆ€ν‚€λ₯Ό κΊΌλ‘λŠ” κΈ°λŠ₯을 μ§€μ›ν•˜μ§€ μ•ŠκΈ° λ•Œλ¬Έμ— μ˜ˆμ™Έμ²˜λ¦¬ν•œ ꡬ문

  • truncate() : ν…Œμ΄λΈ”μ— λ‹΄κΈ΄ λͺ¨λ“  데이터λ₯Ό λ²„λ¦¬λŠ” λ©”μ„œλ“œλ‘œ, delete()와 같을 수 μžˆμ§€λ§Œ μ΄λŠ” κΈ°λ³Έν‚€λ₯Ό 1둜 μž¬λ°°μ—΄ν•œλ‹€.

  • call() : $class::run() λ©”μ„œλ“œμ˜ 본문을 μ‹€ν–‰ν•˜κ³  μ½˜μ†”μ— κ²°κ³Όλ₯Ό 좜λ ₯ν•œλ‹€.

php artisan db:seed둜 λ§ˆμŠ€ν„° μ‹œλ“œλ₯Ό μ‹œλ”©ν•  수 μžˆλ‹€.

php artisan migrate:refresh --seed : λ§ˆμ΄κ·Έλ ˆμ΄μ…˜κ³Ό μ‹œλ”©μ„ ν•œλ²ˆμ— μ‹€ν–‰

PreviousscoutNexttntsearch

Last updated 3 years ago