Not touching timestamps for certain field2019 Community Moderator ElectionData not persisted when updating rows with EloquentLaravel: performing some task on every insert/update when using Query Builder or Eloquent ORMUpdate without touching timestamps (Laravel)Laravel DB and Eloquent designLaravel Relationship/JOIN not workingLaravel changes created_at on updateEloquent 5.4 - HasMany Object Mass Update TimestampsEloquent updateOrCreate() overwrites all rows - trying to understand itHow to createOrUpdate complex Eloquent models with auditing history saved automaticallyEloquent model considered 'dirty' despite no underlying values have changed due to encrypted values
Does anyone draw a parallel between Haman selling himself to Mordechai and Esav selling the birthright to Yaakov?
What is the blue range indicating on this manifold pressure gauge?
What Happens when Passenger Refuses to Fly Boeing 737 Max?
Playing ONE triplet (not three)
Replacing Windows 7 security updates with anti-virus?
Touchscreen-controlled dentist office snowman collector game
Running a subshell from the middle of the current command
Can infringement of a trademark be pursued for using a company's name in a sentence?
Is all copper pipe pretty much the same?
What exactly is the purpose of connection links straped between the rocket and the launch pad
Excess Zinc in garden soil
What is the likely impact on flights of grounding an entire aircraft series?
Life insurance that covers only simultaneous/dual deaths
What is the difference between "shut" and "close"?
If the Captain's screens are out, does he switch seats with the co-pilot?
Single word request: Harming the benefactor
Can the druid cantrip Thorn Whip really defeat a water weird this easily?
Potentiometer like component
How could a female member of a species produce eggs unto death?
Good allowance savings plan?
Time dilation for a moving electronic clock
Is it ok to include an epilogue dedicated to colleagues who passed away in the end of the manuscript?
Unreachable code, but reachable with exception
Do I need to leave some extra space available on the disk which my database log files reside, for log backup operations to successfully occur?
Not touching timestamps for certain field
2019 Community Moderator ElectionData not persisted when updating rows with EloquentLaravel: performing some task on every insert/update when using Query Builder or Eloquent ORMUpdate without touching timestamps (Laravel)Laravel DB and Eloquent designLaravel Relationship/JOIN not workingLaravel changes created_at on updateEloquent 5.4 - HasMany Object Mass Update TimestampsEloquent updateOrCreate() overwrites all rows - trying to understand itHow to createOrUpdate complex Eloquent models with auditing history saved automaticallyEloquent model considered 'dirty' despite no underlying values have changed due to encrypted values
I have several models with timestamps and active
fields and several parts in my code where I update them.
I want to be able to update the model and only touch timestamps when the updated model changes more than the acttive field.
So my code is
const leaveUntouched=["active"=>true]
...
$instance = $model::find($data["id"]);
$changed = array_diff_assoc($data,$instance->toArray());
$needTimestampTouch = array_diff_key($changed,self::leaveUntouched);
if (empty($needTimestampTouch))
$instance->timestamps = false;
$instance->fill($data);
$instance->save();
It would be much cleaner, if I could define this in the BaseModel itself.
Should I extend the Fill Method of Eloquent/Model in my Baseclass? And how would I do that?
eloquent
add a comment |
I have several models with timestamps and active
fields and several parts in my code where I update them.
I want to be able to update the model and only touch timestamps when the updated model changes more than the acttive field.
So my code is
const leaveUntouched=["active"=>true]
...
$instance = $model::find($data["id"]);
$changed = array_diff_assoc($data,$instance->toArray());
$needTimestampTouch = array_diff_key($changed,self::leaveUntouched);
if (empty($needTimestampTouch))
$instance->timestamps = false;
$instance->fill($data);
$instance->save();
It would be much cleaner, if I could define this in the BaseModel itself.
Should I extend the Fill Method of Eloquent/Model in my Baseclass? And how would I do that?
eloquent
add a comment |
I have several models with timestamps and active
fields and several parts in my code where I update them.
I want to be able to update the model and only touch timestamps when the updated model changes more than the acttive field.
So my code is
const leaveUntouched=["active"=>true]
...
$instance = $model::find($data["id"]);
$changed = array_diff_assoc($data,$instance->toArray());
$needTimestampTouch = array_diff_key($changed,self::leaveUntouched);
if (empty($needTimestampTouch))
$instance->timestamps = false;
$instance->fill($data);
$instance->save();
It would be much cleaner, if I could define this in the BaseModel itself.
Should I extend the Fill Method of Eloquent/Model in my Baseclass? And how would I do that?
eloquent
I have several models with timestamps and active
fields and several parts in my code where I update them.
I want to be able to update the model and only touch timestamps when the updated model changes more than the acttive field.
So my code is
const leaveUntouched=["active"=>true]
...
$instance = $model::find($data["id"]);
$changed = array_diff_assoc($data,$instance->toArray());
$needTimestampTouch = array_diff_key($changed,self::leaveUntouched);
if (empty($needTimestampTouch))
$instance->timestamps = false;
$instance->fill($data);
$instance->save();
It would be much cleaner, if I could define this in the BaseModel itself.
Should I extend the Fill Method of Eloquent/Model in my Baseclass? And how would I do that?
eloquent
eloquent
asked Mar 7 at 10:56
JohannessJohanness
1,56611327
1,56611327
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
For reference:
I put this in my Baseclass and it works:
protected $preventTouch=['active'];
public function save(array $options = [])
$needsUpdate=array_diff(
array_keys($this->getDirty()),
$this->preventTouch
);
$this->timestamps = count($needsUpdate) > 0;
parent::save($options);
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55042121%2fnot-touching-timestamps-for-certain-field%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
For reference:
I put this in my Baseclass and it works:
protected $preventTouch=['active'];
public function save(array $options = [])
$needsUpdate=array_diff(
array_keys($this->getDirty()),
$this->preventTouch
);
$this->timestamps = count($needsUpdate) > 0;
parent::save($options);
add a comment |
For reference:
I put this in my Baseclass and it works:
protected $preventTouch=['active'];
public function save(array $options = [])
$needsUpdate=array_diff(
array_keys($this->getDirty()),
$this->preventTouch
);
$this->timestamps = count($needsUpdate) > 0;
parent::save($options);
add a comment |
For reference:
I put this in my Baseclass and it works:
protected $preventTouch=['active'];
public function save(array $options = [])
$needsUpdate=array_diff(
array_keys($this->getDirty()),
$this->preventTouch
);
$this->timestamps = count($needsUpdate) > 0;
parent::save($options);
For reference:
I put this in my Baseclass and it works:
protected $preventTouch=['active'];
public function save(array $options = [])
$needsUpdate=array_diff(
array_keys($this->getDirty()),
$this->preventTouch
);
$this->timestamps = count($needsUpdate) > 0;
parent::save($options);
answered Mar 7 at 18:29
JohannessJohanness
1,56611327
1,56611327
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55042121%2fnot-touching-timestamps-for-certain-field%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown