mysql的库和表相关操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

一、数据库介绍

1、数据库的由来

我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问,一个文件仅仅只能存在于某一台机器上,这样就带来了许多问题:

(1)程序所有的组件就不可能运行在一台机器上

(2)数据安全问题

(3)并发问题

总结:我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端程序),于是有人将此类程序写成一个专门的处理软件,这就是mysql等数据库管理软件的由来,mysql不仅仅解决的是数据共享的问题,还有查询效率,安全性等一系列问题,总之,把程序员从数据管理中解脱出来,专注于自己的程序逻辑的编写。


2、数据库说明

数据库服务器 -:运行数据库管理软件

数据库管理软件:管理 - 数据库

数据库:即文件夹,用来组织文件 / 表

表:即文件,用来存放多行内容 / 多条记录


3、mysql介绍

MySQL是一个关系型数据库管理系统

(1)分两大类:

  关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用

  非关系型:mongodb,redis,memcache

(2)可以简单的理解为:

    关系型数据库需要有表结构

    非关系型数据库是key-value存储的,没有表结构

二、操作

1、mysql数据库环境准备

环境:window7_X86_64

版本:mysql-5.6.38-winx64.zip

下载地址:https://dev.mysql.com/downloads/mysql/

文件路径:E:\mysql-5.6.38-winx64

添加到环境变量:计算机---->属性---->高级系统设置---->环境变量---->系统变量---->path---->E:\mysql-5.6.38-winx64\bin\;


2、登录和设置密码

1
2
3
4
5
C:\Users\Administrator> mysqld  - - install
C:\Users\Administrator> net start MySQL                    #启动mysql数据库
C:\Users\Administrator> mysql                          #默认用户不用密码可以直接登录
mysql> select user();                                #查看当前登录用户,显示的是ODBC用户
C:\Users\Administrator> mysqladmin  - uroot  - p password  "123"      #设置root账号的密码是123

3、重置密码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
C:\Users\Administrator> net stop MySQL
C:\Users\Administrator> mysqld  - - skip - grant - tables
 
新打开一个终端操作:
C:\Users\Administrator> mysql  - uroot  - p
mysql > update mysql.user  set  password = password(" ") where user='root' and host=" localhost";
mysql > flush privileges;
mysql> exit;
C:\Users\Administrator>tasklist |findstr mysql              #查看mysql服务的进程号
mysqld.exe          6316  Console           1     454 , 544  K
 
C:\Users\Administrator>taskkill  / / PID  6316                #结束mysql服务
C:\Users\Administrator>net start MySQL                   #启动mysql服务
C:\Users\Administrator> mysql  - uroot  - p                   #登录不需要密码了


4、同一字符编码

#mysql5.5以上的配置文件配置

[mysqld]

character-set-server=utf8

collation-server=utf8_general_ci

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8


mysql> show variables like '%char%';                           #查看字符编码


5、SQL语言介绍

SQL语言主要用于存取数据、查询数据、更新数据和管理关系数据库系统,SQL语言由IBM开发。SQL语言分为3种类型:

#1、DDL语句    数据库定义语言: 数据库、表、视图、索引、存储过程,例如CREATE DROP ALTER

#2、DML语句    数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT

#3、DCL语句    数据库控制语言: 例如控制用户的访问权限GRANT、REVOKE


(1)操作文件夹

增:create database db1 charset utf8;

查:show databases;

改:alter database db1 charset latin1;

删除: drop database db1;


(2)操作文件

先切换到文件夹下:use db1

增:create table t1(id int, name char);

查:show tables

改:alter table t1 modify name char(3); alter table t1 change name name1 char(2);

删:drop table t1;


(3)操作文件中的内容/记录

增:insert into t1 values(1, 'egon1'), (2, 'egon2'), (3, 'egon3');

查:select * from t1;

改:update t1 set name = 'sb' where id = 2;

删:delete from t1 where id = 1;


清空表:

    delete from t1;  # 如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

    truncate table t1; 数据量大,删除速度比上一条快,且直接从零开始,

    auto_increment 表示:自增

    primary key    表示:约束(不能重复且不能为空);加速查找

6、库操作

(1)查看数据库

show databases;

show create database db1;

select database();

(2)选择数据库

USE 数据库名

(3) 删除数据库

DROP DATABASE 数据库名;

(4)修改数据库

alter database db1 charset utf8;


7、表操作

(1)创建表

#注意:

        1. 在同一张表中,字段名是不能相同

        2. 宽度和约束条件可选

        3. 字段名和类型是必须的


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> show engines;                       #显示所有的存储引擎
mysql> use db1
mysql> create table t1( id  int )engine = innodb;
mysql> create table t2( id  int )engine = myisam;
mysql> create table t3( id  int )engine = memory;
mysql> create table t4( id  int )engine = blackhole;
mysql> show tables;                           #查看db1库下的所有的表名
mysql> desc t1;  
                             #查看t1表的表结构
#memory存储引擎,在重启mysql或者重启机器后,表内数据清空
#blackhole存储引擎,往表内插入任何数据,都相当于丢入黑洞,表内永远不存记录
 
mysql> create table db1.f2 select user,host  from  mysql.user;           #复制表
mysql> create table db1.f3 select user,host  from  mysql.user where  1 = 2 ;     #只复制表结构(查询的结果不存在,没有值)
mysql> create table db1.f4 like mysql.user;                       #只复制表结构

(2)日期类型

1
2
3
4
5
6
7
8
9
10
11
create table student(
     id  int ,
     name char( 16 ),
     born_year year,
     birth_date date,
     class_time time,
     reg_time datetime
);
 
insert into student values( 1 , 'wang' ,now(),now(),now(),now());                      #插入当前时间
insert into student values( 2 , 'wang' , '1999' , '1999-11-11' , '11:11:11' , "1990-11-11 11:11:11" );   #插入指定时间

(3)字符类型

#char类型:定长,简单粗暴,浪费空间,存取速度快

    字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)

#varchar类型:变长,精准,节省空间,存取速度慢

    字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8)

#常用字符串系列:char与varchar

注:虽然varchar使用起来较为灵活,但是char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡


#宽度代表的是字符的个数

create table t6(name char(5));

create table t7(name varchar(5));


(4)修改表ALTER TABLE

语法:

#1.修改表名

ALTER TABLE 表名 RENAME 新表名;


#2.增加字段

ALTER TABLE 表名

        ADD 字段名 数据类型[完整性约束条件…],

        ADD 字段名 数据类型[完整性约束条件…];

ALTER TABLE 表名

        ADD 字段名 数据类型[完整性约束条件…]  FIRST;

ALTER TABLE 表名

        ADD 字段名 数据类型[完整性约束条件…]  AFTER 字段名;


#3.删除字段

ALTER TABLE 表名

        DROP 字段名;


#4.修改字段

ALTER TABLE 表名

        MODIFY 字段名 数据类型[完整性约束条件…];

ALTER TABLE 表名

        CHANGE 旧字段名 新字段名 旧数据类型[完整性约束条件…];

ALTER TABLE 表名

        CHANGE 旧字段名 新字段名 新数据类型[完整性约束条件…];


#5.删除表

DROP TABLE 表名;


示例:

#1.修改存储引擎

mysql > alter table service engine = innodb;


#2.添加字段

1
2
3
4
5
6
mysql > alter table student10
         - > add name varchar( 20 not  null,
         - > add age  int ( 3 not  null default  22 ;
         
mysql > alter table student10 add stu_num varchar( 10 not  null after name;           / /  添加name字段之后
mysql > alter table student10 add sex enum( 'male' 'female' ) default  'male'  first;      / /  添加到最前面

#3.删除字段

mysql > alter table student10 drop sex;

mysql > alter table service drop mac;


#4.修改字段类型modify

mysql > alter table student10 modify age int(3);

mysql > alter table student10 modify id int(11) not null primary key auto_increment;    // 修改为主键


#5.增加约束(针对已有的主键增加auto_increment)


mysql > alter table student10 modify id int(11) not null auto_increment;


#6.对已经存在的表增加复合主键

mysql > alter table service2 add primary key(host_ip, port);


#7.增加主键

mysql > alter table student1 modify name varchar(10) not null primary key;


#8.增加主键和自动增长

mysql > alter table student1 modify id int not null primary key auto_increment;


#9.删除主键

a.删除自增约束

mysql > alter table student10 modify id int(11) not null;


b.删除主键

mysql > alter table student10 drop primary key;


(5)枚举类型与集合类型

字段的值只能在给定范围中选择,如单选框,多选框

enum 单选 只能在给定的范围内选一个值

set 多选 在给定的范围内可以选择一个或一个以上的值


1
2
3
4
5
6
7
8
create table employee(
     id  int ,
     name char( 10 ),
     sex enum( 'male' , 'female' , 'other' ),
     hobbies  set ( 'play' , 'eat' , 'music' , 'read' )
);
insert into employee values( 1 , 'li' , 'male' , 'music,read' );
insert into employee values( 2 , 'wang' , 'xxxx' , 'music,read' );




本文转自 宋鹏超 51CTO博客,原文链接:http://blog.51cto.com/qidian510/2072077,如需转载请自行联系原作者
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
SQL 监控 关系型数据库
MySQL 延迟从库介绍
本文介绍了MySQL中的延迟从库功能,详细解释了其工作原理及配置方法。延迟从库允许从库在主库执行完数据变更后延迟一段时间再同步,主要用于快速恢复误操作的数据。此外,它还可用于备份、离线查询及数据合规性需求。通过合理配置,可显著提升数据库系统的稳定性和可靠性。
197 4
|
4月前
|
SQL 关系型数据库 MySQL
MySQL操作利器——mysql-connector-python库详解
MySQL操作利器——mysql-connector-python库详解
1049 0
|
6月前
|
SQL 运维 关系型数据库
MySQL 中 GRANT 操作会引起复制中断吗?
GRANT 操作并不是一个原子性操作,不管执行成功与否,都会触发一个隐式重载授权表的行为。 在生产环境中需要规范用户创建及授权的操作,不推荐使用 DML 语句去直接变更 mysql.user 表,可能会引发其他的问题,若使用了 DML 语句进行变更, 需要手工执行 flush privileges。
88 4
|
6月前
|
JavaScript 关系型数据库 MySQL
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
83 0
|
2月前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
80 5
|
2月前
|
SQL DataWorks 关系型数据库
阿里云 DataWorks 正式支持 SelectDB & Apache Doris 数据源,实现 MySQL 整库实时同步
阿里云数据库 SelectDB 版是阿里云与飞轮科技联合基于 Apache Doris 内核打造的现代化数据仓库,支持大规模实时数据上的极速查询分析。通过实时、统一、弹性、开放的核心能力,能够为企业提供高性价比、简单易用、安全稳定、低成本的实时大数据分析支持。SelectDB 具备世界领先的实时分析能力,能够实现秒级的数据实时导入与同步,在宽表、复杂多表关联、高并发点查等不同场景下,提供超越一众国际知名的同类产品的优秀性能,多次登顶 ClickBench 全球数据库分析性能排行榜。
|
2月前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
59 1
|
3月前
|
存储 关系型数据库 MySQL
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
53 2
|
3月前
|
Oracle 关系型数据库 MySQL
shell获取多个oracle库mysql库所有的表
请注意,此脚本假设你有足够的权限访问所有提到的数据库。在实际部署前,请确保对脚本中的数据库凭据、主机名和端口进行适当的修改和验证。此外,处理数据库操作时,务必谨慎操作,避免因错误的脚本执行造成数据损坏或服务中断。
51 0
|
5月前
|
监控 关系型数据库 MySQL
mysql误删的performance_schema库
`performance_schema`库是MySQL性能监控的重要工具,误删除后可以通过上述方法尝试恢复。在操作过程中,重启MySQL服务器是最简单的尝试方法。如果这不起作用,可以尝试使用MySQL的初始化选项,但请注意备份数据以防数据丢失。检查MySQL配置也是一个好的步骤,以确保 `performance_schema`没有被禁用。最后,如果有备份,通过恢复备份来恢复 `performance_schema`库是最保险的方法。在操作过程中,确保遵循最佳实践和操作前备份重要数据。
272 5