北京pk赛车官网下载:Mysql复制表结构,数据库操作

(风流洒脱卡塔尔将旧表复制到新表

正文给我们享受了少数种复制表结构、表数据的亲自过问介绍,具体实际情况请看下文吧。

CREATE TABLE EMP1 AS SELECT * FROM EMP WHERE EMPNO=1

1、CREATE
TABLE新表
SELECT*
FROM旧表;

1、复制表结构及数码到新表

SELECT * INTO NEW_TABLE FROM EMP WHERE EMPNO=1   (IF NEW_TABLE IS EXIST ) 

该语句只是复制表结构以致数额,它不会复制与表关联的别样数据库对象,如索引,主键约束,外键约束,触发器等。

CREATE TABLE 新表SELECT * FROM 旧表

 

 

这种方法会将oldtable中持有的内容都拷贝过来,当然大家可以用delete from
newtable;来删除。

1.create database name; //创造数据库 (create 内部命令)

  1. CREATE TABLE if not exists new_table

  2. SELECT col1, col2, col3

  3. FROM

  4. existing_table

  5. WHERE

  6. conditions;

只是这种格局的三个最倒霉之处就是新表中从未了旧表的primary
key、Extra(auto_increment卡塔 尔(阿拉伯语:قطر‎等个性。要求团结用”alter”增多,况兼轻松搞错。

  mysql>create  database  ;

2、MySQL 数据库不帮衬 SELECT … INTO
语句,但扶植 INSERT INTO …
SELECT 

2、只复制表结构到新表

2.use databasename; //接收数据库 (use内部命令)

里面在动用select
 into 语句与insert into select
语句时,新表要超前建立,况兼新表与旧表的字段属性要生龙活虎律才可以。

CREATE TABLE 新表SELECT * FROM 旧表WHERE 1=2

  mysql>use  ;

create
table 新表 like 旧表;

或CREATE TABLE 新表LIKE 旧表

3.drop database name; //直接删除数据库,不晋升 (drop内部命令)

新表建设构造现在才方可采用上边包车型地铁多个语句:

3、复制旧表的数码到新表(如若七个表结构肖似)

  mysql>drop  database  ;

SELECT * INTO 新表   FROM  旧表;

INSERT INTO 新表SELECT * FROM 旧表

4.drop table name; // 直接删除表

INSERT INTO  新表  SELECT * FROM  旧表;

4、复制旧表的数目到新表(假诺四个表结构不相近)

  mysql>drop  table  ;

只复制希望的列插入到另贰个已存在的表中:

INSERT INTO 新表(字段1,字段2,…….) SELECT 字段1,字段2,…… FROM
旧表

5.create table name; //创建表

INSERT INTO  新表  (column_name(s))
 SELECT   column_name(s)  FROM  旧表;

5、能够将表1布局复制到表2

  mysql>create  table  ;

实例:INSERT INTO Websites (name,
country) SELECT
app_name, country FROM
apps;

SELECT * INTO 表2 FROM 表1 WHERE 1=2

      **前提是先mysql>use;

 

6、能够将表1内容总体复制到表2

6.show databases;//彰显全部数据库

(二卡塔尔国复制相近表结构

SELECT * INTO 表2 FROM 表1

  mysql>show  databases;

 

7、 show create table 旧表;

7.show tables; //呈现数据库中的表 (show内部命令)

对于mysql的复制相近表结构方式,有create
table as 和create table like 三种

那样会将旧表的开创命令列出。我们只要求将该命令拷贝出来,修改table的名字,就足以创建贰个通通等同的表

  mysql>show  tables;

create table 新表 like
旧表;

8、mysqldump

      **提前是先mysql>use;

create table 新表 as select
* from 旧表 limit 0;

用mysqldump将表dump出来,改名字后再导回去大概直接在命令行中运维

8.describe tablename; //展现表的详细描述

双方的区分:

9、复制旧数据库到新数据库(复制全体表结构何况复制全体表数据卡塔尔国

  mysql>describe ;

 

#mysql -u root -ppassword
>CREATE DATABASE new_db;
#mysqldump old_db -u root -ppassword–skip-extended-insert
–add-drop-table | mysql new_db -u root -ppassword

9.select version(),current_date; //呈现当前mysql版本和眼后天子

as用来创制肖似表结构并复制源表数据

10、表不在同后生可畏数据库中(如,db1 table1, db2 table2)
sql: insert into db1.table1 select * from db2.table2 (完全复制)
insert into db1.table1 select distinct * from
db2.table2(不复制重复纪录卡塔 尔(阿拉伯语:قطر‎
insert into tdb1.able1 select top 5 * from db2.table2
(前五条纪录)以上内容便是本文的整套呈报,希望大家赏识。

  mysql>select  version(), current_date;

like用来创立完整表结构和全体索引

您也许感兴趣的稿子:

  • MYSQL METADATA LOCK(MDL
    LOCK)MDL锁难题剖析
  • mysql中复制表结构的艺术小结
  • MySQL复制表结交涉剧情到另一张表中的SQL语句
  • MySQL更正表结构操作命令总括
  • Navicat for
    MySQL导出表结构脚本的总结方法
  • MySQL优化之表结构优化的5大提出(数据类型接纳讲的很好卡塔尔
  • mysql校勘表结构方式实例详明
  • MySQL中期维校勘表结构时索要注意的片段地点
  • MySQL数据源表结构图示
  • MySQL表结构改换你不可不知的Metadata
    Lock详细解释

  mysql>select  version(),

oracle帮忙as,也是只有表结构未有索引
oracle不支持like。

      ->current_date;

(三卡塔尔MySQL复制表到另三个数据库

  **select 内部命令 

做客不一样数据库中的表:数据库名.表名 ,采取点
的方式。

10.mysql>flush privileges ; //刷新数据库

不经常,您要将表复制到其余数据库。 在这里种情况下,可接收以下语句:

11.mysql达成校正客商密码:

  1. CREATE TABLE destination_db.new_table

  2. LIKE source_db.existing_table;

  3.  

  4. INSERT destination_db.new_table

  5. SELECT *

  6. FROM source_db.existing_table;

 11.1 update //修改

SQL

       shell>mysql -u root -p

切实流程:

     mysql> update mysql.user set password=PASSWORD(’新密码’) where
User=’root’;

  1. CREATE DATABASE IF NOT EXISTS testdb;

     mysql> flush privileges;

SQL

     mysql> quit

其次,通过将其布局从示例数据库(yiibaidb)中的offices表复制出来,在testdb中创立了offices表。

 11.2 mysqladmin//改进客户密码

  1. CREATE TABLE testdb.offices LIKE yiibaidb.offices;

     shell>mysqladmin -u root password new_password

SQL

 11.3 自身测验未经过

其三,大家将数据从yiibaidb.offices表复制到testdb.offices表中。

     shell>mysql -u root -p

  1. INSERT testdb.offices

  2. SELECT *

  3. FROM yiibaidb.offices;

    mysql>SET PASSWORD FOR root=PASSWORD(“root”);

 

12.创设帐号

(四卡塔尔MySQL数据库导入导出

  mysql> grant all(delete,updatae,create,drop,insert) privileges on
*.* to @localhost identified  by  ;

1、使用mysqldump工具将数据库导出并转储到sql文件:mysqldump -u 用户名 -p 数据库名 > 导出的文书名  mysqldump -h IP -u 客商名 -p 数据库名 > 导出的公文名

2 :(导出某张表的表结构不含数据)
mysqldump -h localhost -u root -p -d test pollution >
G:arcgisworkspacezypdoctest.sql
3:(导出某张表的表结构和数量,不加-d)
mysqldump -h 127.0.0.1 -u root -p test pollution >
G:arcgisworkspacezypdoctest.sql
mysqldump-u
root -p yiibaidb >d:database_bakyiibaidb.sql
里头>表示导出。
2、导入sql文件
在MySQL中新建数据库,那时候是空数据库,如新建多少个名称为news的目的数据库
create database if not exists news;
use news;
导入文本:
source 路线+导入的文书名; 
source d:mysql.sql;

 

要复制贰个MySQL数据库,您须要试行以下步骤:

  • 首先,使用CREATE
    DATABASE说话创造多个新的数据库。
  • 其次,使用mysqldump工具导出要复制的数据库的装有数据库对象和数码。
  • 其三,将SQL转储文件导入新的数据库。

用作贰个演示,要是要把yiibaidb数据库复制到yiibaidb_backup数据库:

步骤1, 创建yiibaidb_backup数据库:

先是,登陆到MySQL数据库服务器:

C:UsersAdministrator> mysql -u root -p
Enter password: **********

Shell

然后,使用CREATE DATABASE语句如下:

  1. CREATE DATABASE yiibaidb_backup;

SQL

第三,使用SHOW
DATABASES一声令下验证:

  1. SHOW DATABASES

SQL

 

步骤2

 

使用mysqldump工具将数据库对象和多少转储到SQL文件中。

假诺要将数据库对象和数据库转储到放在D:database_bak文本夹的SQL文件中,这里是以下命令:

  1. C:UsersAdministrator> mysqldump -u root -p yiibaidb > d:database_bakyiibaidb.sql

  2. Enter password: **********

SQL

基本上,此命令提示mysqldump应用具备密码的root顾客帐户登陆到MySQL服务器,并将数据库对象和yiibaidb数据库的数目导出到d:database_bakyiibaidb.sql
请注意,运算符(>)表示导出。

步骤2

d:database_bakyiibaidb.sql文本导入到yiibaidb_backup数据库。

C:UsersAdministrator> mysql -u root -p yiibaidb_backup < d:database_bakyiibaidb.sql
Enter password: **********

Shell

请注意,运算符(<)表示导入。

要验证导入,能够接纳SHOW TABLES指令神速检查。

mysql> SHOW TABLES FROM yiibaidb_backup;

13.重命名表:

 

  mysql > alter table   rename  ; //把表t1重命名字为t2

14.备份数据库

 14.1 导出一切数据库

          mysqldump -u 顾客名 -p 数据库名 > 导出的文件名

        mysqldump -u root -p asb >d:asb.sql

 

 14.2 导出多个表

    mysqldump -u 客商名 -p 数据库名 表名> 导出的文本名

mysqldump -u root -p asb yg>d:yg.sql

 

 14.3 导出一个数据库结构

mysqldump -u wcnc -p -d –add-drop-table smgp_apps_wcnc
>d:wcnc_db.sql

// (-d 未有数量 –add-drop-table 在每一种create语句在此以前扩张三个drop table)

  mysqldump mysqladmin外界命令

 

 14.4 导入数据库

  /*用source 命令

  */步入mysql数据库调整台,先创建数据库,use数据库

  mysql -u root -p

  mysql>create  ;

  mysql>use

  mydql>source d:.sql;

 

 14.5 导入表

 // 进入数据库,实施导入操作

      mysql>use;

      mysql>source d:.sql;

15.将表中著录清空:

  mysql>delete  from ;

15.1将表中著录清空:

  mysql>Truncate  tablename;

16.显示表中的记录:

  mysql>select  *  from ;

17.四个建库和建表以至插入数据的实例

  Drop  database  if  exists  school;  //假使存在SCHOOL则删除

  create  database  school;  //建立库SCHOOL

  use  school;  //打开库SCHOOL

  create  table  teacher  //建立表TEACHER

  (

  id  int(3)  auto_increment  not  null  primary  key,

  name  char(10)  not null,

  address  varchar(50)  default  ‘深圳’,

  year  date

  );  //建表结束

  //以下为插入字段

  insert into teacher values(”,’glchengang’,’温哥华一中’,’一九七七-10-10′);

  insert into teacher values(”,’jack’,’布里斯班一中’,’1974-12-23′);

**注:在建表中

(1) 将ID设为长度为3的数字字段:int(3),并让它每种记录自动加黄金年代:
auto_increment,

并不可能为空:not null,何况让它产生主字段primary key

(2) 将NAME设为长度为10的字符字段

(3)
将ADDRESS设为长度50的字符字段,并且缺省值为蒙特利尔。varchar和char有哪些不同

呢,独有等以后的随笔再说了。

(4) 将YEAXC90设为日期字段。

假若你在mysql提醒符键入上面的指令也能够,但不便利调节和测量检验。 你能够将以上命令

面相写入一个文本文件中风流倜傥经为school.sql,然后复制到c:下,并在DOS状态步向目录

mysqlin,然后键入以下命令:

mysql -uroot -p密码 < c:school.sql

借使成功,空出意气风发行无此外展现;如有错误,会有提醒。(以上命令已经调节和测量试验,你

即使将//的讲明去掉就可以使用卡塔尔国。

将文件数据转到数据库中

 文本数据应顺应的格式:字段数据里面用tab键隔开分离,null值用来代替。例:

3 rose 柏林(Berlin卡塔 尔(阿拉伯语:قطر‎二中 1979-10-10

4 mike 柏林一中 1975-12-23

 数据传入命令load data local infile “文件名” into table 表名;

注意:你最佳将文件复制到mysqlin目录下,並且要先用use命令选表所在的库。

18.revoke all on database from user

//移除user客户在database数据库上的全部权限 (本身测试未经过)

 

19.连接mysql。

格式: mysql -h主机地址 -u顾客名 -p顾客密码

20.登入数据库

  mysql-uroot-p;

  mysql-uroot-pnewpassword;

  mysqlmydb-uroot-p;

  mysql mydb -uroot -pnewpassword;

  mydb数据库名

21.刚安装好的MySql富含一个含空密码的root帐户和二个无名帐户,那是相当的大的安全祸患,对于有个别关键的选用大家应将安全性尽或者进步,  
在这里处应把佚名帐户删除、root帐户设置密码,可用如下命令实行:

  mysql>use mysql;

 mysql>delete from User where User=””;

 mysql>update User set Password=PASSWORD(‘newpassword’) where
User=’root’;

22.新添客商

  格式:grant select on 数据库.* to 顾客名@登入主机 identified by
“密码”

例1、增添叁个客商test1密码为abc,让他得以在其余主机上登入,并对全数数据库有询问、插入、改革、删除的权柄。首先用以root顾客连入MySQL,然后键入以下命令:

mysql>grant select,insert,update,delete on *.* to
[email protected]”%”
Identified by “abc”;

但例1增加的客商是十三分摇摇欲堕的,你想如某一个人领略test1的密码,那么他就足以在internet上的其它黄金年代台Computer上登陆你的MySQL数据库并对您的多寡足感到所欲为了,消除办法见例2。

例2、扩大贰个客商test2密码为abc,让他只可以够在localhost上登陆,并能够对数据库mydb实行查询、插入、订正、删除的操作(localhost指本地主机,即MySQL数据库所在的那台主机卡塔尔国,那样顾客即接受知道test2的密码,他也回天无力从internet上直接待上访谈数据库,只可以通过MySQL主机上的web页来访谈。

mysql>grant select,insert,update,delete on mydb.* to
[email protected]
identified by “abc”;

假使您不想test2有密码,能够再打多少个命令将密码消掉。

mysql>grant select,insert,update,delete on mydb.* to
[email protected]
identified by “”;

下边大家来看看MySQL中有关数据库方面包车型大巴操作。注意:你必得首首先登场入到MySQL中,以下操作都是在MySQL的晋升符下实行的,并且各种命令以分行停止。 

在开展开采和事实上行使中,客户不应当只用root用户举办连接数据库,纵然应用root顾客展开测量检验时很有益,但会给系统带给主要安全祸患,也不方便人民群众管理本领的增高。大家给三个选择中运用的顾客付与最符合的数据库权限。如八个只实行数据插入的客户不应授予其删除数据的权力。MySql的客商管理是由此User表来兑现的,增添新客户常用的议程有四个,一是在User表插入相应的数目行,同一时候设置相应的权位;二是透过GRANT命令创制具备某种权力的客商。此中GRANT的常用用法如下:

  mysql>grant all on mydb.* to
[email protected]
identified by “password”;

  mysql>grant usage on *.* to
[email protected]
identified by “password”;

  mysql>grant select,insert,update on mydb.* to
[email protected]
identified by “password”;

  mysql>grant update,delete on mydb.TestTable to
[email protected]
identified by “password”;

23.对常用权限的解说:

   23.1 全局管理权限: 

  FILE:在MySQL服务器上读写文件。 

  PROCESS:展现或杀死归属其余客商的服务线程。 

  RELOAD:重载访谈调整表,刷新日志等。 

  SHUTDOWN:关闭MySQL服务。

 23.2 数据库/数据表/数据列权限: 

  Alter:更正已存在的数据表(比方扩充/删除列)和目录。 

  Create:创建新的数据库或数据表。 

  Delete:删除表的记录。 

  Drop:删除数据表或数据库。 

  INDEX:创立或删除索引。 

  Insert:扩充表的笔录。 

  Select:突显/搜索表的笔录。 

  Update:纠正表中已存在的笔录。

 23.3 非常的权杖: 

  ALL:允许做别的事(和root同样)。 

  USAGE:只同意登陆–别的什么也分歧意做。

 

末尾交给在RedHat9.0下的MySql操作演示:

选择数据库的root客户登陆

 
[[email protected]]$mysql
-uroot -p

  Enterpassword:MyPassword

  mysql>create database mydb;

  QueryOK,1rowaffected(0.02sec)

  mysql>use mydb;

  Databasechanged

  mysql>create table TestTable(Idintaut_increment primary key,

  UserNamevarchar(16) not null,

  Address varchar(255));

  QueryOK,0rowsaffected(0.02sec)

  mysql>grant all on mydb.* to
[email protected]
identified by “test”;

  QueryOK,0rowsaffected(0.01sec)

  mysql>quit

  Bye

 
[[email protected]]$mysqlmydb
-utest -ptest

个中test.sql是用vi编辑好的SQL脚本,其剧情为:

  Insert into TestTable(UserName,Address) values(‘Tom’,’shanghai’);

  Insert into TestTable(UserName,Address) values(‘John’,’beijing’);

  select * from TestTable;

运维已经编写制定好的SQL脚本能够用source filename或.filename。

上述只是对新手的大概操练,要成为叁个数据库好手,当以努力地追求学问,不断地思量、尝试、再思考。

24.MySql常用命令计算 

 24.1 使用SHOW语句寻觅在服务器上如今设有如何数据库: 

  mysql>SHOW DATABASES; 

 24.2 创立二个数据库 

  mysql>Create  DATABASE  ;

 24.3 选拔你所创设的数据库 

  mysql>USE ;(按回车键现身Databasechanged时表明操作成功!) 

 24.4 查看以后的数据库中设有怎么样表 

  mysql>SHOW TABLES; 

 24.5 创制一个数据库表 

  mysql>Create  TABLE(name VARCHAR(20),sex CHAR(1)); 

 24.6 呈现表的结构: 

  mysql>DESCRIBE ;

 24.7 往表中进入记录 

  mysql>insert  into values(“hyq”,”M”); 

 24.8 用文件方式将数据装入数据库表中(比如D:/mysql.txt卡塔 尔(英语:State of Qatar) 

  mysql> LOAD DATA LOCAL INFILE “D:/mysql.txt” INTO TABLE; 

 24.9 导入.sql文件命令(举例D:/mysql.sql卡塔 尔(阿拉伯语:قطر‎ 

  mysql>use  database; 

  mysql>source  d:/mysql.sql; 

 24.10 删除表 

  mysql>drop  TABLE  ; 

 24.11 清空表 

  mysql>delete  from  ; 

 24.12 更新表中数据 

  mysql>update  set  sex=”f”  where  name=’hyq’;

 

 

  1. –通过伪列rowid查找重复数据

 

select a.* from t_user a where a.rowid!= 

  (select max(rowid) as rid from t_user where a.grpid =grpid and
a.uname=uname);

 

delete from t_user a where a.rowid!= 

  (select max(rowid) as rid from t_user where a.grpid =grpid and
a.uname=uname);

 

  1. 当表中有重复数据(全部字段相通卡塔尔时,去重:

select distinct * from  ;

 

  1. 听说字段查询表中重新的数码(单一字段卡塔 尔(阿拉伯语:قطر‎:

    select * fromwhere 字段名 in (select字段名   from  group by 字段名
having  count(字段名) > 1);

 

28:
删除表中多余的重复记录,重复记录是基于单个字段(peopleId卡塔 尔(英语:State of Qatar)来判定,只留有rowid最小的笔录
       delete from where  字段名  in (select  字段名   from    group  
by  字段名   having   count(字段名) > 1)
and rowid not in (select min(rowid) from      group by字段名   having
count(字段名)>1);

29:依据字段查表里面重复的多字段数据,并显示重复次数:

    Select 字段名1,字段名2,Count(*) From 表名 Group By 字段名1,字段名2
Having Count(*) > 1

  1. 钦点查询表中前N行数据:

    select * fromlimit  N;

31.钦定查询表中第N行后的M行数据:

    select * from limit N,M;

  1. 复制表结构及数量到新表
    CREATE TABLE 新表 SELECT * FROM 旧表;

  2. 只复制表结构到新表
    CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2
    或CREATE TABLE 新表  LIKE 旧表;

  3. 1、复制表结构及数码到新表
    CREATE TABLE 新表 SELECT * FROM 旧表
    这种方法会将oldtable中颇有的源委都拷贝过来,当然我们能够用delete from
    newtable;来删除。
    可是这种方法的二个最不佳之处便是新表中并未有了旧表的primary
    key、Extra(auto_increment卡塔尔等属性。须求自身用"alter"加多,而且便于搞错。

2、只复制表结构到新表
CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2
或CREATE TABLE 新表  LIKE 旧表

3、复制旧表的数据到新表(要是多个表结构同样)
INSERT INTO 新表 SELECT * FROM 旧表

4、复制旧表的数码到新表(即便多个表结构不意气风发致)
INSERT INTO 新表(字段1,字段2,…….) SELECT 字段1,字段2,…… FROM
旧表

5、能够将表1组织复制到表2
SELECT * INTO 表2 FROM 表1 WHERE 1=2

6、能够将表1剧情全方位复制到表2
SELECT * INTO 表2 FROM 表1

7、show create table 旧表;
那样会将旧表的创造命令列出。大家只供给将该命令拷贝出来,修改table的名字,就可以创立贰个截然风流罗曼蒂克致的表

8、mysqldump
用mysqldump将表dump出来,改名字后再导回去也许直接在指令行中运维

  1. 把日子更新成为当前系统时间

Update set =now();

 

TABLE EMP1 AS
SELECT * FROM EMP WHERE EMPNO=1 SELECT
* INTO NEW…

发表评论

电子邮件地址不会被公开。 必填项已用*标注