Copy Table with Condition : Copy Table « Table Index « SQL / MySQL

Home
SQL / MySQL
1.Aggregate Functions
2.Backup Load
3.Command MySQL
4.Cursor
5.Data Type
6.Database
7.Date Time
8.Engine
9.Event
10.Flow Control
11.FullText Search
12.Function
13.Geometric
14.I18N
15.Insert Delete Update
16.Join
17.Key
18.Math
19.Procedure Function
20.Regular Expression
21.Select Clause
22.String
23.Table Index
24.Transaction
25.Trigger
26.User Permission
27.View
28.Where Clause
29.XML
PostgreSQL
MySQL Tutorial
SQL / MySQL » Table Index » Copy Table 
Copy Table with Condition
  
/*

mysql> Select * from Employee;
+----------+---------------+------+
| Name     | PhoneNo       | Age  |
+----------+---------------+------+
| John Doe | Unknown Phone |   31 |
+----------+---------------+------+
1 row in set (0.00 sec)

mysql> /* Now copy the table */
mysql> CREATE TABLE MyEmployee SELECT FROM Employee
    -> where Age > 30;
Query OK, row affected (0.08 sec)
Records: 1  Duplicates: 0  Warnings: 0

mysql> Describe MyEmployee;
+---------+-------------+------+-----+---------------+-------+
| Field   | Type        | Null | Key | Default       | Extra |
+---------+-------------+------+-----+---------------+-------+
| Name    | varchar(50|      |     |               |       |
| PhoneNo | varchar(15| YES  |     | Unknown Phone |       |
| Age     | int(11)     | YES  |     | NULL          |       |
+---------+-------------+------+-----+---------------+-------+
rows in set (0.00 sec)

mysql> select from MyEmployee;
+----------+---------------+------+
| Name     | PhoneNo       | Age  |
+----------+---------------+------+
| John Doe | Unknown Phone |   31 |
+----------+---------------+------+
row in set (0.00 sec)


*/
Drop TABLE Employee;
Drop TABLE MyEmployee;

CREATE TABLE Employee (
   Name    VARCHAR(50PRIMARY KEY NOT NULL, 
   PhoneNo VARCHAR(15DEFAULT 'Unknown Phone',
   Age     INT CHECK (Age BETWEEN 20 and 30));

Describe Employee;

INSERT INTO Employee (Name, Phone, AgeVALUES ('Joe Wang', '666 2323', 26);
INSERT INTO Employee (Name, AgeVALUES ('John Doe', 31);

Select * from Employee;


/* Now copy the table */  
CREATE TABLE MyEmployee SELECT FROM Employee 
where Age > 30;


Describe MyEmployee;

select from MyEmployee;
           
         
    
  
Related examples in the same category
1.Copy Table Demo
2.Copying a Table
3.Use NULL in where clause
4.Copy table with conditions
5.Only copy records
6.Using the INSERT Statement to Copy Data
7.Using the REPLACE Statement to Copy Data
8.Copy a table
9.Only copy certain columns
10.Copy one row of data
11.Copy data to temporary table
12.Creating New Tables with SELECT Results
13.Copying Only Selected Data from a Table
14.Copy table with calculation
15.Copying Data into a New Table
16.MySQL truncates the data during copying
java2s.com  |  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.