473,396 Members | 1,734 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

PLS HELP! - show databases and tables and columns

Hi,

I just wonder if someone can help me with this:
I need to create a sql script which will run when user installs/upgrades my app.
User may already have the database and tables tructure setup on the server, or may not.

The script needs to conditionally create database, conditionally create tables, and conditionally
add columns to the tables if needed.

I could perform this on MS SQL, as the master database has all info about all other
databases/tables/schemas. BUt in MySQL i don't see such an option.

So, i would need this(for description i use a mix of SQL and pseudo-language):

// -------------- CODE START
IF NOT EXISTS( MyDatabase ) CREATE MyDatabase;
USE MyDatabase;
IF NOT EXISTS( MyTable )
CREATE MyTable (
Field1 INT NOT NULL,
Field2 VARCHAR(20),
Field3 INT
)TYPE='MyISAM'

IF NOT EXISTS (Field3 IN MyTable)
ALTER TABLE MyTable ADD Field3 INT
..... etc...
// -------------- CODE END

So if someone could show me the MySQL way to do that, i would really appreciate that!

Thank you,
Andrey
Jul 23 '05 #1
4 1566
d
You could do it in a shell script. Your pseudo code is along the path
to implement it.
--
Jay
http://d2t2fish.blogspot.com

Jul 23 '05 #2
d@t@ wrote:
You could do it in a shell script. Your pseudo code is along the path
to implement it.
--
Jay
http://d2t2fish.blogspot.com


I know that, but i asked how do i translate my pseudo-code to MySQL SQL language?
I don't know how to check if database exists or if table exists or if table's column exists
Jul 23 '05 #3
MuZZy wrote:
I need to create a sql script which will run when user installs/upgrades
my app.
User may already have the database and tables tructure setup on the
server, or may not.
The script needs to conditionally create database, conditionally create
tables, and conditionally add columns to the tables if needed.


You can get partway there using existing MySQL syntax.
See the respect web pages for CREATE DATABASE, DROP TABLE, CREATE TABLE,
etc.

http://dev.mysql.com/doc/mysql/en/create-database.html
CREATE DATABASE IF NOT EXISTS databaseName ...

http://dev.mysql.com/doc/mysql/en/create-table.html
CREATE TABLE IF NOT EXISTS tableName ...

http://dev.mysql.com/doc/mysql/en/drop-table.html
DROP TABLE IF EXISTS tableName ...

But there is no equivalent mechanism for conditional creation of columns.

At least one widely-used project comes to mind that does what you're
describing; runs a script to bring a database schema up to date with
current table/field definitions: Bugzilla.

The setup procedure for Bugzilla involves running a script
checksetup.pl, which can upgrade previous Bugzilla installations to the
current version's required schema. Basically, it does this with
ordinary ALTER TABLE ADD COLUMN statements, but ignores any error
returned (as would happen if the column already exists).

If you want to know more, download Bugzilla at
http://www.bugzilla.org/download/#stable, open the distribution, and
read their checksetup.pl script.

Regards,
Bill K.
Jul 23 '05 #4
Bill Karwin wrote:
MuZZy wrote:
I need to create a sql script which will run when user
installs/upgrades my app.
User may already have the database and tables tructure setup on the
server, or may not.

> The script needs to conditionally create database, conditionally create
> tables, and conditionally add columns to the tables if needed.


You can get partway there using existing MySQL syntax.
See the respect web pages for CREATE DATABASE, DROP TABLE, CREATE TABLE,
etc.

http://dev.mysql.com/doc/mysql/en/create-database.html
CREATE DATABASE IF NOT EXISTS databaseName ...

http://dev.mysql.com/doc/mysql/en/create-table.html
CREATE TABLE IF NOT EXISTS tableName ...

http://dev.mysql.com/doc/mysql/en/drop-table.html
DROP TABLE IF EXISTS tableName ...

But there is no equivalent mechanism for conditional creation of columns.

At least one widely-used project comes to mind that does what you're
describing; runs a script to bring a database schema up to date with
current table/field definitions: Bugzilla.

The setup procedure for Bugzilla involves running a script
checksetup.pl, which can upgrade previous Bugzilla installations to the
current version's required schema. Basically, it does this with
ordinary ALTER TABLE ADD COLUMN statements, but ignores any error
returned (as would happen if the column already exists).

If you want to know more, download Bugzilla at
http://www.bugzilla.org/download/#stable, open the distribution, and
read their checksetup.pl script.

Regards,
Bill K.


Thanks a lot, Bill!
That's exactly what i was looking for!
Jul 23 '05 #5

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

21
by: Dave | last post by:
After following Microsofts admonition to reformat my system before doing a final compilation of my app I got many warnings/errors upon compiling an rtf file created in word. I used the Help...
9
by: Tom | last post by:
A question for gui application programmers. . . I 've got some GUI programs, written in Python/wxPython, and I've got a help button and a help menu item. Also, I've got a compiled file made with...
4
by: Sarir Khamsi | last post by:
Is there a way to get help the way you get it from the Python interpreter (eg, 'help(dir)' gives help on the 'dir' command) in the module cmd.Cmd? I know how to add commands and help text to...
6
by: wukexin | last post by:
Help me, good men. I find mang books that introduce bit "mang header files",they talk too bit,in fact it is my too fool, I don't learn it, I have do a test program, but I have no correct doing...
3
by: Colin J. Williams | last post by:
Python advertises some basic service: C:\Python24>python Python 2.4.1 (#65, Mar 30 2005, 09:13:57) on win32 Type "help", "copyright", "credits" or "license" for more information. >>> With...
7
by: Corepaul | last post by:
Missing Help Files When I enter "recordset" as the keyword and search the Visual Basic Help index, I get many topics of interest in the resulting list. But there isn't any information available...
5
by: Steve | last post by:
I have written a help file (chm) for a DLL and referenced it using Help.ShowHelp My expectation is that a developer using my DLL would be able to access this help file during his development time...
8
by: Mark | last post by:
I have loaded Visual Studio .net on my home computer and my laptop, but my home computer has an abbreviated help screen not 2% of the help on my laptop. All the settings look the same on both...
10
by: JonathanOrlev | last post by:
Hello everybody, I wrote this comment in another message of mine, but decided to post it again as a standalone message. I think that Microsoft's Office 2003 help system is horrible, probably...
1
by: trunxnirvana007 | last post by:
'UPGRADE_WARNING: Array has a new behavior. Click for more: 'ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?keyword="9B7D5ADD-D8FE-4819-A36C-6DEDAF088CC7"' 'UPGRADE_WARNING: Couldn't resolve...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.