User not logged in - login - register
Home Calendar Books School Tool Photo Gallery Message Boards Users Statistics Advertise Site Info
go to bottom | |
 Message Boards » » quick php/mysql question Page [1]  
BigMan157
no u
103353 Posts
user info
edit post

hopefully this is a quick and easy answer for someone

how do you insert a new column with default values into a MySQL table?

i'd assume it'd be some variation of ALTER TABLE tablename ADD COLUMN columnname INT(3), but what would i have to add/change so that i could insert the new column between certain existing columns and to set the column to have a default value?

8/14/2006 10:30:19 PM

qntmfred
retired
40596 Posts
user info
edit post

you're on the right track

http://mysql.com/doc/refman/5.0/en/alter-table.html

ALTER TABLE tablename ADD COLUMN column_definition AFTER col_name

where column_definition is from http://mysql.com/doc/refman/5.0/en/create-table.html

column_definition:
col_name data_type [NOT NULL | NULL] [DEFAULT default_value]
[AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY]
[COMMENT 'string'] [reference_definition]

[Edited on August 14, 2006 at 10:36 PM. Reason : default]

8/14/2006 10:34:37 PM

BigMan157
no u
103353 Posts
user info
edit post

how would i code that column_definition part in php?

would i just be like

$cd="column_definition:
columnname INT(3) DEFAULT 5"


and then

ALTER TABLE tablename ADD COLUMN $cd AFTER col_name

?

[Edited on August 14, 2006 at 10:58 PM. Reason : ]

8/14/2006 10:55:58 PM

qntmfred
retired
40596 Posts
user info
edit post

why are you splitting up the string? just do

$sql = "ALTER TABLE tablename ADD COLUMN columnname INT(3) DEFAULT 5 AFTER col_name";

or if you do need to piece it together

$cd = "columnname INT(3) DEFAULT 5";
$sql = "ALTER TABLE tablename ADD COLUMN $cd AFTER col_name";

8/14/2006 11:01:47 PM

BigMan157
no u
103353 Posts
user info
edit post

oic, i just misunderstood the psuedocode

i hate psuedocode

OK I'M GOOD NOW THX QNTMFRED

8/14/2006 11:04:15 PM

BigMan157
no u
103353 Posts
user info
edit post

ok NEW QUESTION

if i have $ROW = mysql_fetch_object($poop);

and let's say there is a column named cats in there

and $variab = 'cats';

then you do $temp = 'ROW->'.$variab;

NOW,

$ROW->cats should be the same as $$temp, right?

[Edited on September 13, 2006 at 9:50 PM. Reason : because it's not goddamn working]

9/13/2006 9:23:00 PM

BigMan157
no u
103353 Posts
user info
edit post

nevermind, just doing $ROW->{$variab} works

i guess it WAS the -> part

9/13/2006 10:12:33 PM

qntmfred
retired
40596 Posts
user info
edit post

np

9/13/2006 11:01:50 PM

SilentIsrael
All American
1764 Posts
user info
edit post

PHP + mySQL - A Quick Lesson

Here's a breakdown of some code that will connect you to a database & spit out some data...

// Establish Database Connection --------------------------------------

$hostname_connection= "db.dbserver.com"; -- Database server host name
$database_connection= "thisdatabase"; -- Name of database you are connecting to
$username_connection = "admin"; -- Username used to connect to database
$password_connection = "password"; -- Password used to connect
$connection = mysql_pconnect($hostname_connection, $username_connection, $password_connection) or trigger_error(mysql_error(),E_USER_ERROR);

// Select Query to Retrieve Records ------------------------------------

mysql_select_db($database_connection, $connection); -- Select the database
$query_getRecords = "SELECT * FROM table WHERE field1 = 'value1'"; -- Query statement
$getRecords = mysql_query($query_getRecords, $connection) or die(mysql_error()); -- Execute query using the database connection.
$row_getRecords = mysql_fetch_assoc($getRecords); -- Creates array of data in each row.
$totalRows_getRecords = mysql_num_rows($getRecords); -- Find the total number of rows


// Finding out the values

$value1 = $row_getRecords['field1'];
$value2 = $row_getRecords['field2'];

Let's say your database tabke is setup like this

field1 | field2 | field3
---------------------
Mike | Tom | Gary <---------- Row1
--------------------
Dave | John | Kelly <---------- Row2

In this example, $value1 will equal Mike, and $value2 will equal Tom.

Using the same setup, you can set $value3 = $row_getRecords['field3'] (Tom). If you print these values to the screen like so:

<?php echo $value1; ?> // Will print 'Mike'
<?php echo $value2; ?> // Will print 'Tom'
<?php echo $value3; ?> // Will print 'Gary'


You can do a do/while statment to make your program loop through the entire database and print out all values:

<?php

do {
echo $value1."<br>";
echo $value2."<br>";
echo $value3."<br>"

} while ($row_getResults = mysql_fetch_assoc($getReults));;
?>

9/13/2006 11:06:05 PM

robster
All American
3545 Posts
user info
edit post

straight out of dreamweaver Makes it pretty easy ehh.

9/14/2006 7:55:54 AM

SilentIsrael
All American
1764 Posts
user info
edit post

Right as rained - it's how I learned.

9/14/2006 10:31:00 AM

 Message Boards » Tech Talk » quick php/mysql question Page [1]  
go to top | |
Admin Options : move topic | lock topic

© 2024 by The Wolf Web - All Rights Reserved.
The material located at this site is not endorsed, sponsored or provided by or on behalf of North Carolina State University.
Powered by CrazyWeb v2.38 - our disclaimer.