Author |
Message |
Gremmie
Former Moderator in Good Standing
data:image/s3,"s3://crabby-images/e0184/e0184c289d846a553594e6ddcdc67f3354a52fed" alt=""
Joined: Apr 06, 2006
Posts: 2415
Location: Iowa, USA
|
Posted:
Sun Jan 07, 2007 6:55 pm |
|
I'm making a module that has several database tables. I would like to provide a PHP script to admins that they can run one time only to create the tables and populate any required initial data when they install the module. The only reason I am considering this is so I can take account the Nuke $prefix. Otherwise I would just give the user an export of the SQL.
Right now I'm thinking of just doing an export on my tables and saving that to a file. And then just use my favorite editor to turn the SQL into PHP. Or maybe write a Perl script to do that. But is there a better way? I didn't see anything in phpMyAdmin for this. Thanks. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
evaders99
Former Moderator in Good Standing
data:image/s3,"s3://crabby-images/c915b/c915ba1715f1389dcc5b042d6c45c550b39402b4" alt=""
Joined: Apr 30, 2004
Posts: 3221
|
Posted:
Sun Jan 07, 2007 10:44 pm |
|
I've not seen anything quite like that. But your approach should work, you could write a script to easily change the SQL exported to PHP code for phpNuke |
_________________ - Only registered users can see links on this board! Get registered or login! -
Need help? Only registered users can see links on this board! Get registered or login! |
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
Site Admin
data:image/s3,"s3://crabby-images/90769/907690f0b3800b7c3631940ce09741fc8d7ec9ba" alt=""
Joined: Aug 29, 2004
Posts: 9457
Location: Arizona
|
Posted:
Sun Jan 07, 2007 11:13 pm |
|
Well, interestingly, I wonder if phpMyAdmin could be used for it. If you took this in steps, you could possibly use the "Create PHP Code" button AFTER you run the particular SQL in question. Copy and paste that out to your editor and then just replace the nuke_ with the appropriate variable. |
_________________ Only registered users can see links on this board! Get registered or login!
Only registered users can see links on this board! Get registered or login! |
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
hitwalker
Sells PC To Pay For Divorce
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
Joined:
Posts: 5661
|
Posted:
Mon Jan 08, 2007 5:21 am |
|
Is Only registered users can see links on this board! Get registered or login! something ? |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 6:43 am |
|
Interesting find hitwalker! Thx. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 8:43 am |
|
montego wrote: | Well, interestingly, I wonder if phpMyAdmin could be used for it. If you took this in steps, you could possibly use the "Create PHP Code" button AFTER you run the particular SQL in question. Copy and paste that out to your editor and then just replace the nuke_ with the appropriate variable. |
Hi montego! I am aware of the "Create PHP Code" button that appears after you run an SQL query. However I am not aware of any SQL query that produces the crazy long CREATE TABLE statement that I am after...if you see what I mean.
A Perl script to process the exported SQL shouldn't be too bad. If I get something to work I'll release it or post it here. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Guardian2003
Site Admin
data:image/s3,"s3://crabby-images/561e7/561e7182bdcacfd2a2232800b5c2bee621501a26" alt=""
Joined: Aug 28, 2003
Posts: 6799
Location: Ha Noi, Viet Nam
|
Posted:
Mon Jan 08, 2007 11:58 am |
|
I'm not sure if the DB compare utility I have on my site will help you with this (its a simple php class file). It should in theory if you use it to compare against an empty database. It will display the sql queries and also provide links which when clicked will execute the query.
You might be able to develop it further for your own specific needs. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 6:26 pm |
|
Guardian2003, thanks a lot that sounds interesting. I will look at that.
I think I found my answer in phpmyAdmin. When looking at a table, there is an Operations tab. Under that tab is a copy table operation. If you copy your table to a new table, it will generate a CREATE TABLE statement. You can then hit the "Create PHP Code" button on the results of the query! I've only got 3 tables so I think I will use that. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 7:50 pm |
|
Gremmie, you missed my point. Your objective as stated in your first post was to provide a PHP script that an admin can run to create the new tables and populate them with the initial data that is needed. Ok, run with this example of say five new tables:
1) During the course of your development you already have the five tables in your development system and the way you want them (make the records in the tables be what you would want for a fresh install too.
2) Export the structure and data -- do not take the autoindex -- to a file and save that off.
3) Come back in mySQL and drop those tables.
4) Now copy and paste the SQL you saved off into a file into the phpMyAdmin SQL executer. Once it is done, you can click on the said "Button" and there is your SQL as PHP!
What am I missing here? |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 8:12 pm |
|
montego wrote: |
What am I missing here? |
Yeah, that would work too.
I didn't think about exporting it, dropping it, and re-importing it, then hitting the "Create PHP Code" button. You are a genius!
Copying and then dropping the copy also gets the same result.
I think I'm sleep deprived..... data:image/s3,"s3://crabby-images/b4d54/b4d54a5965c4f3f194e5ef0416760621372998c3" alt="Very Happy" |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Jan 08, 2007 10:01 pm |
|
Actually, I was thinking that maybe I was cracked and sleep deprived so I was needing help to understand why phpMyAdmin could not be used.
Take care and good luck! |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
fkelly
Former Moderator in Good Standing
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
Joined: Aug 30, 2005
Posts: 3312
Location: near Albany NY
|
Posted:
Mon Jan 08, 2007 11:23 pm |
|
Just a thought. If you want a full PHP script, take a look at what Raven did with the installSQL.php program that comes in the INSTALLATION folder. It runs in conjunction with the sql files in the INSTALLATION/sql directory. It won't generate your CREATE statements for you but if you have those it will give your admins a menu driven way to install the tables. You don't need the whole thing probably but take a look at the way it reads in the SQL and processes it a line at a time. |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Tue Jan 09, 2007 8:28 am |
|
montego, that's why I use these forums, to bounce ideas of you pros to keep myself out of the ditch (and off the crack pipe).
fkelly, thanks. I was already looking at the NukeSentinel installer scripts for ideas too. I got a skeleton script running last night. data:image/s3,"s3://crabby-images/aac24/aac2483665ae15bd71498360df4c319f040e7934" alt="Cool" |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
|