澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

澳门新萄京官方网站:mysql复制表以及复制数据库

2019-05-06 作者:数据库网络   |   浏览(187)

(1)将旧表复制到新表

正文给我们大饱眼福了有些种复制表结构、表数据的言传身教介绍,具体实际情况请看下文吧。

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

0、复制表结构及数据到新表
CREATE TABLE 新表 SELECT * FROM 旧表
那种方法会将oldtable中负有的从头到尾的经过都拷贝过来,当然大家能够用delete from newtable;来删除。
可是这种情势的一个最不佳的地方便是新表中并未有了旧表的primary key、Extra(auto_increment)等属性。需求本身用"alter"增多,而且便于搞错。

1、操作某数据库 use 数据库名称,然后能够操作该数据库下的某张表

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

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

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

 

2、$res=mysql_query($sql); 该语句假诺用在包装的函数体里,
则毫不传入第贰个参数$conn来内定连接,那样工夫使用到该函数体外面已张开的连接;
mysql_query() 向与钦赐的连日标志符关联的服务器中的当前移动
数据库发送一条查询。要是未有点名 link_identifier,则接纳上一
个张开的连年。如若未有展开的总是,本函数会尝试无参数调用
mysql_connect() 函数来确立三个连接并行使之。查询结果会被缓存。

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

CREATE TABLE 新表SELECT * FROM 旧表

 

 

三,数据库查询
清空数据表,并让自增的id从一起初 truncate table sharon

 

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

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


求差集
SELECT hotelcode FROM 0hotelone WHERE hotelno =1 AND hotelcode NOT
IN (SELECT hotelcode FROM 0hotel_freedom WHERE hno =1);
大约询问
SELECT * FROM `0hotelone` WHERE hotelno=1 and hotelcode=3702;
分组查询
SELECT hotelcode , hno FROM `0hotel_freedom` WHERE hno=37 group by hotelcode;
数据库操作语句
翻开当前留存的数据库show databases;
创设数据库create database 数据库名称;
翻看数据库的创造语句:show create database 数据库名称(已创设的);
去除数据库Drop database 数据库名称;
修改数据库消息Alter database 数据库名称 修改命令;
修改数据库名称:简单的可以一直退换目录名;
将数据库内容总体导出,新建三个数据库将数据导入,删除旧数据库;
始建叁个新数据库,将就数据库内的表,都活动(重命名)到新数据库内,删除旧数据库。

  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  ;

 

制造表(创造前先选拔数据库)
Create table tbl_name [列结构][表选项]
先分析须求保留的实业数据具备啥样属性,那几个属性应该怎么保存。

二、MySQL 数据库不援助 SELECT ... INTO 语句,但支撑 INSERT INTO ... SELECT 

二、只复制表结构到新表

二.use databasename; //选取数据库 (use内部命令)

 

MyISAM与InnoDB是mysql近年来可比常用的七个数据仓库储存款和储蓄引擎,MyISAM与InnoDB的首要的区别点在于品质和事务调控上。
MyISAM:MyISAM是MySQL伍.5此前版本暗中认可的数据仓库储存款和储蓄引擎。MYISAM提供火速存款和储蓄和索求,以及全文检索本领,适合数据仓库等查询频仍的行使。但不援救职业、也不扶助外键。MyISAM格式的多个主要缺陷正是无法在表损坏后卷土而来数据。
InnoDB:InnoDB是MySQL伍.5版本的默许数据仓库储存款和储蓄引擎,可是InnoDB已被Oracle收购,MySQL自行开辟的新存款和储蓄引擎Falcon将要MySQL陆.0版本引入。InnoDB具备提交、回滚和崩溃复苏工夫的政工业安全全。但是比起MyISAM存款和储蓄引擎,InnoDB写的拍卖功用差不离而且会占领越来越多的磁盘空间以保留数据和目录。就算如此,但是InnoDB包含了对事务管理和外来键的支撑,这两点都以MyISAM引擎所未曾的。
MyISAM适合:(壹)做过多count 的猜想;(2)插入不频繁,查询非凡频繁;(三)失掉工作。
InnoDB适合:(1)可信性须求相比高,或然需要职业;(二)表更新和询问都一定的往往,并且表锁定的空子十分的大的事态。(肆)品质较好的服务器,举例单独的数据库服务器,像Ali云的关系型数据库宝马7系DS就推荐使用InnoDB引擎。

里头在运用select  into 语句与insert into select 语句时,新表要提前创设,并且新表与旧表的字段属性要平等才足以。

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

  mysql>use  ;

 

查询wpsql库
mysql> use wpsql;

create table 新表 like 旧表;

或CREATE TABLE 新表LIKE 旧表

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

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

列出近来库全数表名
mysql> show tables;
将wp_posts表修为InnoDB存款和储蓄引擎(也足以此命令将InnoDB换为MyISAM):
mysql> ALTER TABLE wp_posts ENGINE=INNODB;

新表构建之后工夫够运用上面包车型大巴五个语句:

三、复制旧表的数目到新表(假如七个表结构一样)

  mysql>drop  database  ;

create table score_youxiu select * from score where grade >90;

 

SELECT * INTO 新表   FROM  旧表;

INSERT INTO 新表SELECT * FROM 旧表

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

//复制表的局地故事情节

6、修改,删除主键
修改在此之前先删除自增auto increment;
除去主键 alter table table_name drop primary key;
注:在增加主键在此以前,必须先把反复的id删除掉。
修改主键 alter table table_test add primary key(id);

INSERT INTO  新表  SELECT * FROM  旧表;

四、复制旧表的多少到新表(假如三个表结构不雷同)

  mysql>drop  table  ;

create table score_youxiu select * from score where id%4=0;

若以上不能够做到,重建一张新表,把旧表的中您要求的数码插入新表

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

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

5.create table name; //创建表

//应用:分表办法(按工作必要,取模(id%4),取偏移量)

7、把那张表中的多寡插入到另一张表中
INSERT INTO `planpoint`.`0hotelone_img0` (no,hotelno,hotelcode,big,small,tag)
SELECT no,hotelno,hotelcode,big,small,tag
FROM `planpoint`.`0hotelone_img` order by no;

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

5、能够将表一组织复制到表二

  mysql>create  table  ;

 

八、导入数据库表 (在cmd中程导弹入)
如已有数据库则创设数据库(1)(2)可粗略
   (1)创建.sql文件
   (二)先产生2个库如auction.c:mysqlbin>mysqladmin -u root -p creat planpoint 会提醒输入密码,然后成功开创。
   (2)导入auction.sql文件
   c:mysqlbin>mysql -u root -p planpoint < auction.sql
   通过以上操作,就足以成立了2个数据库planpoint以及中间的三个表auction

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

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

      **前提是先mysql>use;


二、导出数据中的表结商谈数目(cmd中程导弹出)
一.导出任何数据库
   mysqldump -u用户名 -p密码 数据库名 > 导出的文书名
   C:Usersjack> mysqldump -uroot -pmysql sva_rec > e:sva_rec.sql

 

陆、能够将表一剧情总体复制到表二

陆.show databases;//显示全数数据库

 

   2.导出一个表,包括表结议和数据
   mysqldump -u用户名 -p密码 数据库名 表名> 导出的文件名
   C:Usersjack> mysqldump -uroot -pmysql sva_rec date_rec_drv> e:date_rec_drv.sql

(二)复制同样表结构

SELECT * INTO 表2 FROM 表1

  mysql>show  databases;

 

   3.导出贰个数据库结构
   C:Usersjack> mysqldump -uroot -pmysql -d sva_rec > e:sva_rec.sql

 

7、 show create table 旧表;

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

 

  四.导出二个表,唯有表结构
   mysqldump -u用户名 -p 密码 -d数据库名 表名> 导出的文件名
   C:Usersjack> mysqldump -uroot -pmysql -d sva_rec date_rec_drv> e:date_rec_drv.sql

对于mysql的复制同样表结构形式,有create table as 和create table like 三种

那样会将旧表的创立命令列出。大家只需求将该命令拷贝出来,改换table的名字,就能够创设2个通通等同的表

  mysql>show  tables;

二、复制旧表的数额到新表(假使多个表结构同样)
INSERT INTO 新表 SELECT * FROM 旧表

 

create table 新表 like 旧表;

澳门新萄京官方网站,8、mysqldump

      **超前是先mysql>use;

 

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

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

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

 

两岸的分别:

九、复制旧数据库到新数据库(复制全部表结构并且复制全体表数据)

  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用来创设一样表结构并复制源表数据

十、表不在同一数据库中(如,db1 table一, db二 table2)
sql: insert into db1.table1 select * from db2.table2 (完全复制)
insert into db1.table1 select distinct * from db二.table二(不复制重复纪录)
insert into tdb1.able1 select top 5 * from db贰.table2(前5条纪录)以上内容正是本文的成套叙述,希望大家高兴。

  mysql>select  version(), current_date;

 

like用来创设完整表结构和全体目录

你或者感兴趣的作品:

  • MYSQL METADATA LOCK(MDL LOCK)MDL锁难点分析
  • mysql中复制表结构的措施小结
  • MySQL复制表结商谈剧情到另一张表中的SQL语句
  • MySQL修改表结构操作命令总括
  • Navicat for MySQL导出表结构脚本的简便方法
  • MySQL优化之表结构优化的中国共产党第五次全国代表大会提议(数据类型选择讲的很好)
  • mysql修改表结构格局实例详解
  • MySQL中期维修改表结构时必要注意的1部分地点
  • MySQL数据源表结构图示
  • MySQL表结构改换你不可不知的Metadata Lock详解

  mysql>select  version(),

三、复制旧表的数额到新表(假使多个表结构不等同)
INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 旧表

oracle扶助as,也是唯有表结构未有索引
oracle不支持like。

      ->current_date;

insert into ss (id,stu_id) select id,stu_id from score;

(三)MySQL复制表到另叁个数据库

  **select 内部命令 

insert into score3 (id,stu_id,c_name) select id,stu_id,c_name from score;

走访不相同数据库中的表:数据库名.表名 ,选择点 的样式。

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

 

偶尔,您要将表复制到其余数据库。 在那种情景下,可应用以下语句:

1一.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';

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

  1. CREATE DATABASE IF NOT EXISTS testdb;

     mysql> flush privileges;

 

SQL

     mysql> quit


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

 1一.二 mysqladmin//修改用户密码

 

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

     shell>mysqladmin -u root password new_password

 

SQL

 1壹.3 自个儿测试未经过

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

其三,我们将数据从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");


 

1二.创造帐号

 

(四)MySQL数据库导入导出

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

 

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

贰 :(导出某张表的表结构不含数据)
mysqldump -h localhost -u root -p -d test pollution > G:arcgisworkspacezypdoctest.sql
叁:(导出某张表的表结谈判数据,不加-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话语创制1个新的数据库。
  • 其次,使用mysqldump工具导出要复制的数据库的享有数据库对象和多少。
  • 其3,将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;

1三.重命名表:

6、show create table 旧表;
诸如此类会将旧表的创导命令列出。我们只需求将该命令拷贝出来,更换table的名字,就足以成立一个截然1致的表

 

  mysql > alter table   rename  ; //把表t一重命名叫t2

 

1④.备份数据库


 1四.一 导出全部数据库

 

          mysqldump -u 用户名 -p 数据库名 > 导出的公文名

 

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

7、mysqldump
用mysqldump将表dump出来,改名字后再导回去或然间接在命令行中运营

 

 

 14.二 导出贰个表


    mysqldump -u 用户名 -p 数据库名 表名> 导出的公文名

 

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

 

 

八、复制旧数据库到新数据库(复制全体表结构并且复制整体表数据)

 1四.三 导出一个数据库结构

#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

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

 

// (-d 没有多少 --add-drop-table 在种种create语句从前扩张3个drop table)


  mysqldump mysqladmin外部命令

 

 

 

 14.肆 导入数据库

9、表不在同壹数据库中(如,db壹 table1,  db贰 table2)
sql: insert into db1.table1 select * from db二.table贰 (完全复制)
     insert into db1.table1 select distinct * from db二.table2(不复制重复纪录)
     insert into tdb1.able1 select top 5 * from   db贰.table二(前5条纪录) 

  /*用source 命令

 

  */进入mysql数据库调整台,先创制数据库,use数据库


  mysql -u root -p

 

  mysql>create  ;

  mysql>use

  mydql>source d:.sql;

 

 14.5 导入表

 // 进入数据库,试行导入操作

      mysql>use;

      mysql>source d:.sql;

壹5.将表中著录清空:

  mysql>delete  from ;

一伍.壹将表中著录清空:

  mysql>Truncate  tablename;

1六.出示表中的笔录:

  mysql>select  *  from ;

一7.三个建库和建表以及插入数据的实例

  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','卡塔尔多哈一中','一9七九-拾-拾');

  insert into teacher values('','jack','尼科西亚一中','1975-12-23');

**注:在建表中

(1) 将ID设为长度为三的数字字段:int(三),并让它每一种记录自动加1: auto_increment,

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

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

(3) 将ADDRESS设为长度50的字符字段,而且缺省值为尼科西亚。varchar和char有如何分化

呢,唯有等现在的小说再说了。

(四) 将YEA君越设为日期字段。

假定你在mysql提示符键入上面的通令也能够,但不便宜调节和测试。 你能够将以上命令

外貌写入三个文书文件中一经为school.sql,然后复制到c:下,并在DOS状态进入目录

mysqlin,然后键入以下命令:

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

如若成功,空出壹行无任何展现;如有错误,会有提醒。(以上命令已经调节和测试,你

假如将//的解说去掉就可以使用)。

将文件数据转到数据库中

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

3 rose 布拉迪斯拉发第22中学 一九七九-十-10

四 mike 卡萨布兰卡一中 1975-1二-二3

 数据传入命令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数据库名

2壹.刚安装好的MySql包罗1个含空密码的root帐户和二个佚名帐户,这是极大的安全隐患,对于有个别器重的行使大家应将安全性尽只怕提升,   在此处应把佚名帐户删除、root帐户设置密码,可用如下命令实行:

  mysql>use mysql;

 mysql>delete from User where User="";

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

2②.新添用户

  格式:grant select on 数据库.* to 用户名@登陆主机 identified by "密码"

例一、扩大二个用户test一密码为abc,让他得以在别的主机上登陆,并对全部数据库有询问、插入、修改、删除的权杖。首先用以root用户连入MySQL,然后键入以下命令:

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

但例一扩张的用户是这个高危的,你想如有些人驾驭test一的密码,那么她就足以在internet上的其它壹台计算机上登入你的MySQL数据库并对你的多少足认为所欲为了,化解办法见例贰。

例2、扩展二个用户test二密码为abc,让他只可以够在localhost上登入,并能够对数据库mydb进行询问、插入、修改、删除的操作(localhost指当地主机,即MySQL数据库所在的那台主机),那样用户即选取知道test2的密码,他也无能为力从internet上间接待上访问数据库,只可以通过MySQL主机上的web页来访问。

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

假如您不想test二有密码,能够再打3个指令将密码消掉。

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

下边大家来探视MySQL中关于数据库方面的操作。注意:你不可能不首首先登场入到MySQL中,以下操作都以在MySQL的提示符下举办的,而且各样命令以总局甘休。 

在展开开垦和骨子里使用中,用户不该只用root用户张开接二连三数据库,即使选拔root用户张开测试时很便利,但会给系统带来主要安全隐患,也不便宜管理工夫的滋长。大家给1个施用中利用的用户赋予最方便的数据库权限。如三个只举办数据插入的用户不应赋予其删除数据的权力。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";

2三.对常用权限的解释:

   二叁.一 全局管理权限: 

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

  PROCESS:展现或杀死属于另外用户的劳务线程。 

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

  SHUTDOWN:关闭MySQL服务。

 2三.2 数据库/数据表/数据列权限: 

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

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

  Delete:删除表的笔录。 

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

  INDEX:创设或删除索引。 

  Insert:扩充表的笔录。 

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

  Update:修改表中已存在的笔录。

 23.三 尤其的权能: 

  ALL:允许做此外交事务(和root同样)。 

  USAGE:只同意登陆--别的什么也不容许做。

 

澳门新萄京官方网站:mysql复制表以及复制数据库,Mysql复制表结构。终极交给在RedHat九.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。

以上只是对菜鸟的简易练习,要成为三个数据库好手,当以困苦地追求学问,不断地商讨、尝试、再思虑。

贰4.MySql常用命令总计 

 2四.一 使用SHOW语句搜索在服务器上脚下设有啥样数据库: 

  mysql>SHOW DATABASES; 

 2四.贰 创制1个数目库 

  mysql>Create  DATABASE  ;

 二4.叁 选择你所开创的数目库 

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

 2四.肆 查看未来的数据库中留存哪些表 

  mysql>SHOW TABLES; 

 二四.伍 创立一个数据库表 

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

 二四.6 展现表的组织: 

  mysql>DESCRIBE ;

 2四.7 往表中参与记录 

  mysql>insert  into values("hyq","M"); 

 二四.8 用文件情势将数据装入数据库表中(举个例子D:/mysql.txt) 

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

 贰4.玖 导入.sql文件命令(比方D:/mysql.sql) 

  mysql>use  database; 

  mysql>source  d:/mysql.sql; 

 24.10 删除表 

  mysql>drop  TABLE  ; 

 24.11 清空表 

  mysql>delete  from  ; 

 2肆.1二 更新表中数据 

  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);

 

2八: 删除表中多余的重复记录,重复记录是基于单个字段(peopleId)来判别,只留有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);

2九:依据字段查表里面重复的多字段数据,并体现重复次数:

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

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

    select * fromlimit  N;

3一.点名查询表中第N行后的M行数据:

    select * from limit N,M;

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

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

  3. 一、复制表结构及数量到新表
    CREATE TABLE 新表 SELECT * FROM 旧表
    这种方法会将oldtable中保有的开始和结果都拷贝过来,当然我们可以用delete from newtable;来删除。
    唯独那种方式的三个最倒霉的地点正是新表中绝非了旧表的primary key、Extra(auto_increment)等属性。供给自个儿用"alter"增添,而且便于搞错。

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

叁、复制旧表的数目到新表(要是八个表结构同样)
INSERT INTO 新表 SELECT * FROM 旧表

四、复制旧表的多寡到新表(假使多少个表结构不1致)
INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 旧表

伍、能够将表一协会复制到表二
SELECT * INTO 表2 FROM 表1 WHERE 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...

本文由澳门新萄京官方网站发布于数据库网络,转载请注明出处:澳门新萄京官方网站:mysql复制表以及复制数据库

关键词: