Storing contents of a PHP array in a MySQL database

前端 未结 3 1798
清酒与你
清酒与你 2021-01-24 03:24

I am having trouble storing array contents in mysql I am using the code below

foreach($found_entry as $key => $sd) {
         echo \"$key => $sd 
相关标签:
3条回答
  • 2021-01-24 03:37

    Adding data to MySQL with a PHP Array


    Inserting data into MySQL

    In your code you are performing an insert for every field.

    However, in most cases you know the field names before hand and so you can do a single INSERT with all of the fields.

    $sql = 'INSERT INTO tbl_name (field_a,field_b,field_c) VALUES('.$found_entry['field_a'].','.$found_entry['field_b'].','.$found_entry['field_c'].');';
    

    This cuts down on the number of queries required and so makes your code run faster and use less resources.

    Default values

    You can pass NULL when a value is not known and the DB should insert a default value.

    0 讨论(0)
  • 2021-01-24 03:40

    Your query syntax is wrong. Use SET instead of VALUES. Also, you probably don't need the foreach loop at all, as you are referencing both $sd[0] and $sd[11]. Try something like this:

    $query = sprintf("INSERT INTO
                 myTable
             SET
                 ID = '%s',
                 folder = NULL,
                 Tsi = '%s',
                 PT = 'NA'",
                 mysql_real_escape_string($found_entry[0]),
                 mysql_real_escape_string($found_entry[11])
             );
    
    mysql_query($query) or die(mysql_error());
    
    0 讨论(0)
  • 2021-01-24 03:45

    If I use $sd[0], only the first character is getting displayed.

    $sd is the value (e.g. "ST10928") of your array, but you're treating the value as an array itself, so $sd[0] must return only the first element (= letter).

    If you're trying to insert values from your array into the database (instead of iterating through the array and slicing the values), maybe you should use $found_entry[0] instead of $sd[0] and $found_entry[11] for $sd[11] ??

    0 讨论(0)
提交回复
热议问题