staudenmeir

staudenmeir

Member Since 3 Years Ago

Munich, Germany

Experience Points
99,100
Total
Experience

900 experience to go until the next level!

In case you were wondering, you earn Laracasts experience when you:

  • Complete a lesson — 100pts
  • Create a forum thread — 50pts
  • Reply to a thread — 10pts
  • Leave a reply that is liked — 50pts
  • Receive a "Best Reply" award — 500pts
Lessons Completed
0
Lessons
Completed
Best Reply Awards
162
Best Reply
Awards
  • start your engines Created with Sketch.

    Start Your Engines

    Earned once you have completed your first Laracasts lesson.

  • first-thousand Created with Sketch.

    First Thousand

    Earned once you have earned your first 1000 experience points.

  • 1-year Created with Sketch.

    One Year Member

    Earned when you have been with Laracasts for 1 year.

  • 2-years Created with Sketch.

    Two Year Member

    Earned when you have been with Laracasts for 2 years.

  • 3-years Created with Sketch.

    Three Year Member

    Earned when you have been with Laracasts for 3 years.

  • 4-years Created with Sketch.

    Four Year Member

    Earned when you have been with Laracasts for 4 years.

  • 5-years Created with Sketch.

    Five Year Member

    Earned when you have been with Laracasts for 5 years.

  • school-in-session Created with Sketch.

    School In Session

    Earned when at least one Laracasts series has been fully completed.

  • welcome-newcomer Created with Sketch.

    Welcome To The Community

    Earned after your first post on the Laracasts forum.

  • full-time-student Created with Sketch.

    Full Time Learner

    Earned once 100 Laracasts lessons have been completed.

  • pay-it-forward Created with Sketch.

    Pay It Forward

    Earned once you receive your first "Best Reply" award on the Laracasts forum.

  • subscriber Created with Sketch.

    Subscriber

    Earned if you are a paying Laracasts subscriber.

  • lifer Created with Sketch.

    Lifer

    Earned if you have a lifetime subscription to Laracasts.

  • evangelist Created with Sketch.

    Laracasts Evangelist

    Earned if you share a link to Laracasts on social media. Please email [email protected] with your username and post URL to be awarded this badge.

  • chatty-cathy Created with Sketch.

    Chatty Cathy

    Earned once you have achieved 500 forum replies.

  • lara-veteran Created with Sketch.

    Laracasts Veteran

    Earned once your experience points passes 100,000.

  • 10k-strong Created with Sketch.

    Ten Thousand Strong

    Earned once your experience points hits 10,000.

  • lara-master Created with Sketch.

    Laracasts Master

    Earned once 1000 Laracasts lessons have been completed.

  • laracasts-tutor Created with Sketch.

    Laracasts Tutor

    Earned once your "Best Reply" award count is 100 or more.

  • laracasts-sensei Created with Sketch.

    Laracasts Sensei

    Earned once your experience points passes 1 million.

  • top-50 Created with Sketch.

    Top 50

    Earned once your experience points ranks in the top 50 of all Laracasts users.

Level 20
99,100 XP
Apr
10
1 month ago
Activity icon

Replied to How To Query Json Column Array.

@skeith22 Use this:

$query->whereJsonContains('users', [['user_id' => 1]])
Apr
09
1 month ago
Activity icon

Replied to Performant Way To Mass "update Or Create"

@mathewparet The package will be way faster than updateOrCreate(). It allows you to insert/update thousands of records in a single query, while updateOrCreate() executes two queries per record.

What database are you using?

Mar
05
2 months ago
Activity icon

Awarded Best Reply on WhereJsonContains Empty Result

It's possible like this:

$path = Test::selectRaw("json_search(`postcodes`, 'one', ?) as `path`", ['32400'])->first()->path;

preg_match('/($\.state\[\d+\])\.city\[\d+\]/', $path, $matches);

$state = Test::selectRaw("json_unquote(json_extract(`postcodes`, '".$matches[1].".name')) as `state`")->first()->state;

$city = Test::selectRaw("json_unquote(json_extract(`postcodes`, '".$matches[0].".name')) as `city`")->first()->city;

dd($state, $city);
Activity icon

Replied to WhereJsonContains Empty Result

Sorry, the code got changed by the editor:

preg_match('/(\$\.state\[\d+\])\.city\[\d+\]/', $path, $matches);
Activity icon

Replied to WhereJsonContains Empty Result

What's the result of dd($path);?

Mar
04
2 months ago
Activity icon

Replied to WhereJsonContains Empty Result

It's possible like this:

$path = Test::selectRaw("json_search(`postcodes`, 'one', ?) as `path`", ['32400'])->first()->path;

preg_match('/($\.state\[\d+\])\.city\[\d+\]/', $path, $matches);

$state = Test::selectRaw("json_unquote(json_extract(`postcodes`, '".$matches[1].".name')) as `state`")->first()->state;

$city = Test::selectRaw("json_unquote(json_extract(`postcodes`, '".$matches[0].".name')) as `city`")->first()->city;

dd($state, $city);
Mar
02
2 months ago
Activity icon

Replied to WhereJsonContains Empty Result

You want to get the state name and the city name from a postcode?

Mar
01
2 months ago
Activity icon

Replied to WhereJsonContains Empty Result

The query needs to look like this:

$settings = CompanySetting::whereJsonContains('postcodes->state', ['name' => 'Perak'])->get();
Feb
28
2 months ago
Activity icon

Awarded Best Reply on Trying To Do A SQLSRV Query Using Cte_sum In Eloquent

Laravel has no native support for common table expressions.

I've created a package for it: https://github.com/staudenmeir/laravel-cte

$sum = YourModel::selectRaw(...)
    ->groupBy(...);

YourModel::withRecursiveExpression('cte_sum', $sum)
    ->select('t.YEAR', 't.QUARTER')
    ->selectRaw(...)
    ->join('cte_sum as t', function ($join) {
        $join->on(...)
            ->on(...);
    })
    ->groupBy('t.YEAR', 't.QUARTER')
    ->orderBy('t.YEAR', 't.QUARTER')
    ->get();
Activity icon

Replied to Trying To Do A SQLSRV Query Using Cte_sum In Eloquent

Laravel has no native support for common table expressions.

I've created a package for it: https://github.com/staudenmeir/laravel-cte

$sum = YourModel::selectRaw(...)
    ->groupBy(...);

YourModel::withRecursiveExpression('cte_sum', $sum)
    ->select('t.YEAR', 't.QUARTER')
    ->selectRaw(...)
    ->join('cte_sum as t', function ($join) {
        $join->on(...)
            ->on(...);
    })
    ->groupBy('t.YEAR', 't.QUARTER')
    ->orderBy('t.YEAR', 't.QUARTER')
    ->get();
Feb
25
2 months ago
Activity icon

Awarded Best Reply on Eloquent Complicate Query

With my package, you can implement the relationship like this:

class Echantillon extends Model
{
    use \Staudenmeir\EloquentHasManyDeep\HasRelationships;

    public function familles()
    {
        return $this->hasManyDeep(
            Famille::class,
            ['echantillon_molecule', Molecule::class],
            [null, null, 'id'],
            [null, null, 'famille_id']
        );
    }
}
Activity icon

Replied to Eloquent Complicate Query

With my package, you can implement the relationship like this:

class Echantillon extends Model
{
    use \Staudenmeir\EloquentHasManyDeep\HasRelationships;

    public function familles()
    {
        return $this->hasManyDeep(
            Famille::class,
            ['echantillon_molecule', Molecule::class],
            [null, null, 'id'],
            [null, null, 'famille_id']
        );
    }
}
Feb
24
3 months ago
Activity icon

Awarded Best Reply on Model Select From Json Column Returns `json_unquote..`

You need a single arrow and an alias:

App\Activity::where('id', 1)->get('name->en as name')
Activity icon

Replied to Model Select From Json Column Returns `json_unquote..`

You need a single arrow and an alias:

App\Activity::where('id', 1)->get('name->en as name')
Feb
04
3 months ago
Activity icon

Replied to Laravel Has Many Through Relation

Please post the structure of all three tables.

Jan
02
4 months ago
Dec
31
4 months ago
Activity icon

Awarded Best Reply on Laravel 5.1 WhereHas('polymorphic')

In your example, the query and the necessary BelongsTorelationships would look like this:

class Comment extends Model
{   
    public function post()
    {
        return $this->belongsTo(Post::class, 'commentable_id');
    }

    public function video()
    {
        return $this->belongsTo(Video::class, 'commentable_id');
    }
}

$relations = ['post', 'video'];

$whereHas = function ($query) {
    $query->whereHas('tags', function ($query) {
        $query->whereIn('id', [1, 2, 3]);
    });
};

$query = Comment::query();

$query->where(function ($query) use ($relations, $whereHas) {
    foreach ($relations as $relation) {
        $related = get_class((new Comment)->$relation()->getRelated());

        $query->orWhere(function ($query) use ($related, $relation, $whereHas) {
            $query->where('commentable_type', (new $related)->getMorphClass())
                ->whereHas($relation, $whereHas);
        });
    }
});

$comments = $query->get();
Dec
20
5 months ago
Activity icon

Replied to Laravel 5.1 WhereHas('polymorphic')

In your example, the query and the necessary BelongsTorelationships would look like this:

class Comment extends Model
{   
    public function post()
    {
        return $this->belongsTo(Post::class, 'commentable_id');
    }

    public function video()
    {
        return $this->belongsTo(Video::class, 'commentable_id');
    }
}

$relations = ['post', 'video'];

$whereHas = function ($query) {
    $query->whereHas('tags', function ($query) {
        $query->whereIn('id', [1, 2, 3]);
    });
};

$query = Comment::query();

$query->where(function ($query) use ($relations, $whereHas) {
    foreach ($relations as $relation) {
        $related = get_class((new Comment)->$relation()->getRelated());

        $query->orWhere(function ($query) use ($related, $relation, $whereHas) {
            $query->where('commentable_type', (new $related)->getMorphClass())
                ->whereHas($relation, $whereHas);
        });
    }
});

$comments = $query->get();
Dec
18
5 months ago
Activity icon

Replied to Laravel 5.1 WhereHas('polymorphic')

Is the code an example or your actual query?