Re: update mysql without manually tying SET statements



Am 16.05.2012 16:12, schrieb apavluck@xxxxxxxxx:
I am trying to setup some generic code that will allow me to update a mysql database via form and php. I can capture the data in the row of the database that I want to update. I can present that in a form populated with the existing values. What I can't figure out how to do is to avoid typing out the SET statements in the update query.

ex

$sql = "update myhugedatabase
SET
reporter = '$_POST[reporter]',
date = '$_POST[date]',
district = '$_POST[district]',
village = '$_POST[village]',
school = '$_POST[school]',
address = '$_POST[address]',
teacher = '$_POST[teacher]',
teacher_contact = '$_POST[teacher_contact]',
alt_teach = '$_POST[alt_teach]',
alt_teach_contact = '$_POST[alt_teach_contact]',
gps = '$_POST[gps]',
etc
etc
etc

The reason I want to do this is because I manage many projects all with their own variables and databases and the update is the only part that I have to type in manually.

If you don't use a framework, you must type in a SET statement for every single
column you want to save in the database. There is no getting around it. You must do
it at least once for every table.

You would normally do even more: apply some test/validation on every field, and make
sure required fields are not empty, and number fields contain numbers...

You do this nowadays with prepared statements, to be protected against SQL injection
attacks.

If you want generic code, you must define the fields and their properties somewhere
else in your code, this is normally not less work.

/Str.


.



Relevant Pages

  • Re: update mysql without manually tying SET statements
    ... $sql = "update myhugedatabase ... The reason I want to do this is because I manage many projects all with their own variables and databases and the update is the only part that I have to type in manually. ...
    (comp.lang.php)
  • Re: SQL Error
    ... SQL: Queries of this type are not supported ... If I replace the trsnsposed variable cJoinField with the actual name of ... This is generic code which I wish to use against different tables / ...
    (microsoft.public.fox.programmer.exchange)
  • update mysql without manually tying SET statements
    ... $sql = "update myhugedatabase ... The reason I want to do this is because I manage many projects all with their own variables and databases and the update is the only part that I have to type in manually. ...
    (comp.lang.php)