Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

mysql query help insert into multiple rows with few fields same

Tags:

sql

php

mysql

I have doubt whether this is possible.

I have two tables

1) file_master

file_id  |  name
-----------------
1        | readme.txt
2        | readme2.txt
3        | readme3.txt
4        | readme4.txt
5        | readme4.txt


2) user_file

user_id  |  file_id
-----------------
1        | 2
1        | 4

I am looking for a query like this

INSERT INTO user_file (user_id, file_id) VALUES (1, SELECT file_id FROM file_master WHERE file_id <= 4);

this should be equivalent to

  INSERT INTO user_file (user_id, file_id) VALUES (1, 1);
  INSERT INTO user_file (user_id, file_id) VALUES (1, 2);
  INSERT INTO user_file (user_id, file_id) VALUES (1, 3);
  INSERT INTO user_file (user_id, file_id) VALUES (1, 4);

In PHP I can construct multiple Insert queries using a for loop. But I am looking for a pure SQL solution... if its possible.

Thanks in advance.

like image 550
phantomCoder Avatar asked May 03 '26 03:05

phantomCoder


1 Answers

INSERT INTO user_file (user_id, file_id)
    SELECT 1, file_id 
    FROM file_master 
    WHERE file_id <= 4;
like image 66
Sebas Avatar answered May 05 '26 17:05

Sebas



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!