On Fri, Aug 15, 2014 at 1:24 PM, Smita <kumarismita62(a)gmail.com> wrote:
Hi,
I came across the bug #4444
<http://sourceforge.net/p/phpmyadmin/bugs/4444/> related to export
feature for queries.
I'm not sure how exactly this feature is supposed to behave if we are
exporting rows with some but not all columns and also in case we have
aliases and even when we have join queries.
We don't have to worry about aliases of table/column names here, just
insert queries should get generated with original names and column selected
in query. Create table can have complete table structure.
Assume we have tables:
actor (actor_id, first_name, last_name, city_id) with actor_id as primary
key.
address (address_id, adress, city_id, city_id, district, postal_code,
phone) with address_id as primary key and phone have not null unique
constraints.
1. when we select some but not all columns ex,
Select address_id, address from address:
when exported few of the rows, it have create table statement for table
'address' with all the original columns not just these two. and data from
just these two columns in the Insert statements. so here when the same
exported file, we wish to import back will not work as phone have unique
constraint and we are not inserting the phone values.
Also If user is seeing just two of the columns in the table structure at
screen so they might be doing export thinking that it will be exporting the
same structure as on the screen.
I remember a discussion over this with Madhura. See
https://sourceforge.net/p/phpmyadmin/bugs/4443/
2. When we have aliases in column names:
ex: select actor_id, first_name as fname from actor;
So when we export few of the resultant rows, should the create table
statement have a column name first_name or fname ?. As I think of it, It
should be fname, if user have in mind that he is exporting the structure of
the table he is looking at screen.
3. When we have alias in table names:
The name of the table in create statement should be alias name or original
table name?
For 2nd and 3rd questions, This feature is implemented and will be present
in 4.3. See RFE #755 & RFE #759.
4. When we have JOIN queries with more than one tables:
ex:
SELECT * FROM (SELECT actor_id FROM actor as e INNER JOIN address as g on
e.actor_id = g.city_id) as t1
Currently if we try to export some rows from the above query, it export
nothing it goes on edit sql screen.
I also remember one discussion over this with Marc. I am quoting his reply
here "exporting a join query makes no sense to me". Also see bug #4445.
Please share your thoughts.
Thanks and Regards
- Smita
--
Regards,
Chirayu Chiripal
phpMyAdmin Intern - Google Summer of Code 2014
https://chirayuchiripal.wordpress.com/