《MySQL数据库》数据导入、导出、表处置惩罚—/—<4> ...

打印 上一主题 下一主题

主题 924|帖子 924|积分 2772

目次
一、插入数据
1、可使用外部工具navicat导入数据的情况下
2、不可使用外部工具navicat导入数据的情况下
1)将数据存入linux当地
2) 从linux当地将数据读入MySQL
● 使用下令 use  ai_03 进入这个库
● 使用查询下令查察数据
二、导出数据
1、从mysql中导出数据文件
2、在MySQL中实行数据文件
三、底子下令补充内容
1、创建数据库
2、 查察当前数据库的建库语句
3、输出数据库
4、切换数据库
5、查察当前使用的数据库
6、单行注释
7、多行注释
8、创建一个表
9、主键(primary key)
10、主键创建方式
1)在创建表时定义主键:
2)在已创建的表上添加主键:
11、书写格式
12、表修改
1)增加列
2)  更改列的属性
3)删除列
4)修改表名称:
5)修改列名
6)修改表的字符集


一、插入数据

1、可使用外部工具navicat导入数据的情况下

由于部分公司不允许使用外部工具去导入数据
        对于大批量数据,除了上节课中使用导入向导插入数据,也可在vscode中打开csv文件,然后选中光标,长按shift+ctrl,拖动滚轮,点击要修改的下面行的位置即可编辑,如图所示
 

        将所有的数据处置惩罚成下列状态ctrl +A选中所有内容,复制到navicat ,即可使用下令将所有数据导入表student中,每一条后面都需要有分号 ";"

将复制的内容粘贴到新建查询中即可


但是这种方式特殊的慢,需要一条一条实行所有下令,那么使用另一种方式即可快速使用导入,
即,删除第一条以外的所有insert in下令,每一条下令后的分号更换成逗号,再在开头结尾加个括号即可

末了一行括号外同样要加个分号
再复制所有内容去navicat中新建查询即可快速导入所有数据。

注意:此时表名student后面没有写括号,也没有再括号内写入字段名,由于后面value值对应的括号内的数据条数以及数据格式和student中创建好的字段一 一对应

2、不可使用外部工具navicat导入数据的情况下

1)将数据存入linux当地

在electerm(终端模仿器)中先将student.csv数据文件存入假造机
点击左上角的sftp即可,左边是当地文件夹,右边是假造机内的文件夹

找到对应文件,直接拖到右侧假造机内即可

然后返回ssh,输入下令ll即可查察


2) 从linux当地将数据读入MySQL

使用下令 use  ai_03 进入这个库


进入MySQL(与在假造机内进入一样,但是更好用更方便)
在MySQL中输入以下下令导入,导入位置为ai_03库的student表,分隔符为','英文逗号,
  1. load data local infile '/root/mysql_pak/students.csv' into table ai_03.students fields terminated by ",";
复制代码
代码解释:
        load data 加载当地文件
        local infile '/root/mysql_pak/students.csv' 当地文件地点
        into table ai_03.students是写入ai_03数据库的student表内,如果你使用了use ai_03进入了这个数据库,那么上述可以直接写表名不用写库名,
        fields terminated by ","; 表示文件分隔符是","号




● 使用查询下令查察数据

  1. select * from student
复制代码
得到如下效果:




二、导出数据


1、从mysql中导出数据文件

使用下令将student表的数据重定向保存到linux当地的student.sql
  1. mysqldump -u root -p ai_03 student -h 192.168.197.100 >student.sql
复制代码

代码解释:
ai_03 student库名和表名,之间用空格分开
-h 192.168.197.100 主机ip地点
>student.sql 重定向到文件student.sql
此时输入下令ll即可查察到linux当地文件,即可发现刚刚保存的文件


此时可以输入下令 vim student.sql 打开文件编辑模式查察文件内容

此时导出到linux当地的是所有内容,此中包罗了student表的建表语句

注意此中每一条数据后面都有 \r 符号,由于linux使用 \r 换行,windows使用 \n 换行

此时可以在electerm左上角的Sftp中把linux当地文件拖入左侧的本机文件,由于我拖入的是桌面文件地点,所以在桌面就看到了这个student.sql文件

其内容就是上图的vim打开对应的文件
此时同样可以在navicat中找到表,然后右击运行SQL文件,然后选中上方谁人文件又可以创建出来新表student


2、在MySQL中实行数据文件

使用下令use ai_03 进入库,然后使用source下令实行数据文件
  1. source /root/student.sql;
复制代码
此中/root/student.sql为数据文件在linux中的地点
运行代码后即可创建一个新表并将数据文件内容写入

三、底子下令补充内容

1、创建数据库

  1. create database if not exists db_name 
复制代码
其意思是:创建一个数据库,定名为db_name,如果当前文件夹没有这个名字的数据库,则成功创建,如果有这个定名,则报错

2、 查察当前数据库的建库语句

  1. show create database db_name
复制代码
即查察数据库定名为db_name的库的建库语句

3、输出数据库

  1. drop database if exists db_name
复制代码
 即如果存在db_name库,则删除,反之报错

4、切换数据库

  1. use database
复制代码

5、查察当前使用的数据库

  1. select database();
复制代码

6、单行注释

两个减号:


7、多行注释

  /*  */


8、创建一个表

  1. create table if not exists tb_name(
  2.     id int primary key
  3.     ,name varchar(255) not null
  4.     ,age int
  5.     ,gender varchar(255)
  6.     ,clazz varchar(255)
  7. );
复制代码
上述代码即创建一个表名为tb_name,如果存在则创建,如果不存在则报错,创建字段名为id、name、age、gender、clazz,其数据类型分别是整型、字符串型、整型、字符串型、字符串型,另外,primary key 表示主键,主键看下列剖析

注意:建表语句末了一句括号后面还有一个下令,定义字符集为utf-8,由于前面已经提前设置过字符集了,所以这里可以不用写这段代码,如图所示

9、主键(primary key)

在MySQL中,主键(Primary Key)是一种用于唯一标识每条记录的列或一组列
主键具有以下特点:

  • 主键列的值必须是唯一的,不能重复。
  • 主键列的值不能为空不能为NULL
  • 主键列的值在表中必须是唯一的标识符,可以用来快速访问和定位表中的记录。
  • 主键可以由一个列或多个列组成,如果由多个列组成,则称为复合主键或联合主键
  • 主键在创建表时可以通过PRIMARY KEY约束进行定义。

10、主键创建方式

1)在创建表时定义主键:

  1. CREATE TABLE table_name (
  2.    column1 datatype PRIMARY KEY,
  3.    column2 datatype,
  4.    ...
  5. );
复制代码
如果设置了主键,之后插入数据时,主键的列,数据有空值大概重复值时会报错
2)在已创建的表上添加主键:

  1. ALTER TABLE table_name ADD PRIMARY KEY (column1);
复制代码
如果数据有控制大概重复值,则增加不了主键

11、书写格式

在使用查询下令的时候,除库名和表名需要严酷遵守大小写格式以外,其他的搜可以随意的大小写,例如:下列代码输出效果就一致
  1. select job from emp;
  2. SELECT job FROM emp;
复制代码
表中字段名是job,现实使用就必须一摸一样,表的名字也是,必须遵守大小写

12、表修改

1)增加列

使用下令
  1. alter table student add length float;
复制代码
即,对student表增加一列,列名为length,数据类型为float类型
例如:
 我有一个表dept ,其数据如下,对其增加一列列名为aaa,数据类型为varchar 的

使用下令 alter table dept add aaaa varchar;
选中实行后得到下列状态

然后刷新dept表即可增加一列


2)  更改列的属性

使用下令
  1. alter table dept modify aaaa int not null;
复制代码
即,将表dept中的列aaaa的字符串类型更改为int型,然后设置为非空属性,即列中的值不能为空
由于我刚增加的列aaaa没有值,所以这个not null属性不用写,不然会报错
3)删除列

使用下令
  1. alter table dept drop aaaa;
复制代码
即,使用drop删除列aaaa

4)修改表名称:

  1. rename table dept to dddpt;
复制代码
将dept表名修改为dddpt

5)修改列名

  1. alter table dddpt change dept_no ddd_no int;
复制代码
即,将dddpt表中的列名dept_no修改为ddd_no,并更改为int型

6)修改表的字符集

alter table student character set utf8;
这种用处不大,最好是从最开始配置的时候就去修改字符集




免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

汕尾海湾

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表