-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dev: Make getInsertID() more consistent with save() #9233
Comments
IMO this may be quite problematic. The Others' code may rely on the fact that So this "small" change may break many things for others. |
It is not Also, this proposal may break existing apps. So it is not acceptable. You should show use cases why you need this, and it seems better to add a new method for it. |
Fair point.
I tried to above; let me be even more clear. If After either operation, we typically need the primary key of the new/updated record in order to do something else with it. Having to perform logic to figure out which model method to use to get that ID means we might as well not have used
Yes, that could also create the consistency I'm talking about. How would we feel about " |
PHP Version
8.2, 8.3
CodeIgniter4 Version
latest
CodeIgniter4 Installation Method
Composer (using
codeigniter4/appstarter
)Which operating systems have you tested for this bug?
macOS, Linux
Which server did you use?
fpm-fcgi
Database
MaraiaDB
What happened?
Not exactly a bug, but not really a FR either. See this forum thread: https://forum.codeigniter.com/showthread.php?tid=91800&pid=421782#pid421782
Essentially I'm offering to PR a change to
\System\Model::update()
that would set an instance's$insertID
property the same way\System\Model::insert()
does so that the behaviour ofsave()
is more consistent.Currently
\System\Model::getInsertID()
only returns a value if asave()
does an insert. The logic needed to handle that works against the elegance provided bysave()
.Steps to Reproduce
Use
\System\Model::save()
Expected Output
Best case,
\System\Model::getInsertID()
will return the "affected ID" after\System\Model::save()
regardless of which action occurred.Anything else?
I'm stoked contribute to core, but I didn't want to spend the time on a PR if there is no desire to change this behaviour. Please advise.
I can write the update to the docs too if I'm pointed in the right direction to do so.
The text was updated successfully, but these errors were encountered: