MySQL数据库管理(一)

news2024/11/22 6:03:33

文章目录

  • 一.数据库基本操作
    • 1.查看数据库结构
      • 1.1 查看数据库信息
      • 1.2 查看数据库中的表信息
      • 1.3 显示数据表的结构(字段)
    • 2.数据库的存储方式
  • 二.数据库管理
    • 1.DDL:数据定义语言
      • 1.1 创建新的数据库
      • 1.2 创建新的表
      • 1.3 删除指定的数据表
      • 1.4 删除指定的数据库
    • 2.DML管理表中的数据记录
      • 2.1 INSERT在表中插入数据
      • 2.2 修改、更新数据表中的数据记录
      • 2.3 在数据表中删除指定的数据记录
    • 3.DQL查询数据记录
    • 4.DCL 数据控制语言
      • 4.1 修改表名和表结构
      • 4.2 扩展表结构(增加字段)
      • 4.3 修改字段(列)名,添加唯一键
      • 4.4 删除字段

一.数据库基本操作

1.查看数据库结构

1.1 查看数据库信息

show databases;

在这里插入图片描述

1.2 查看数据库中的表信息

#切换到书库中
use 数据库名;
#展示库中的表
show tables;
show tables in mysql;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xF86OiHy-1689066431256)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711142119964.png)]

1.3 显示数据表的结构(字段)

describe user;

字段的各个部分含义:

Field:字段名称
type:数据类型
Null :是否允许为空
Key :主键
Type:数据类型
Null :是否允许为空
key :主键
Default :默认值a :扩展属性,例如:标志符列(标Extr识了种子,增量/步长)1 2
id:1 3 5 7

类型含义表示
int整型用于定义整数类型的数据
float单精度浮点4字节32位准确表示到小数点后六位
double双精度浮点8字节64位
char固定长度的字符类型用于定义字符类型数据。 20字节 4 16 空格
varchar可变长度的字符类型
text文本
image图片
decimal(5,2)5个有效长度数字,小数点后面有2位指定长度数组 55555.00

注:Char如果存入数据的实际长度比指定长度要小,会补空格至指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错

主键是唯一的,但主键可以由多个字段构成

2.数据库的存储方式

(1)MySQL数据库的数据文件存放在/usr/local/mysql/data目录下,每个数据库对应一个子目录,用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为“.frm”、“.MYD”和“.MYI”。

(2)MYD”文件是MyISAM存储引擎专用,存放MyISAM表的数据。每一个MyISAM表都会有一个“.MYD”文件与之对应,同样存放于所属数据库的文件夹下,和“.frm”文件在一起。

(3)“.MYI”文件也是专属于 MyISAM 存储引擎的,主要存放 MyISAM 表的索引相关信息。对于 MyISAM 存储来说,可以被 cache 的内容主要就是来源于“.MYI”文件中。每一个MyISAM 表对应一个“.MYI”文件,存放于位置和“.frm”以及“.MYD”一样。

(4)MyISAM 存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件
(frm,myd,myi)。 每个表都有且仅有这样三个文件做为 MyISAM 存储类型的表的存储,也就是说不管这个表有多少个索引,都是存放在同一个.MYI 文件中。

(5)另外还有“.ibd”和 ibdata 文件,这两种文件都是用来存放 Innodb 数据的,之所以有两种文件来存放 Innodb 的数据(包括索引),是因为Innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是独享表空间存放存储数据。独享表空间存储 方式使用“.ibd”文件来存放数据,且每个表一个“.ibd”文件,文件存放在和 MyISAM 数据相同的位置。如果选用共享存储表空间来存放数据,则会使用 ibdata 文件来存放,所有表共同使用一个(或者多个,可自行配置)ibdata 文件。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OT4o5lrz-1689066431256)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711143121274.png)]

二.数据库管理

SQL语句的作用:
SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。

SQL语言分类:

DDL:数据定义语言,用于创建数据库对象,如库、表、索引等
DML:数据操纵语言,用于对表中的数据进行管理,用来插入、删除和修改数据库中的数据
DQL:数据查询语言,用于从数据表中查找符合条件的数据记录
DCL:数据控制语言,用于设置或者更改数据库用户或角色权限(数据控制语句,用于控制不同数据段直接的许可和访问级别的语句,这些语句定义了数据库、表、字段、用户的访问权限和安全级别,如COMMIT、ROLLBACK、GRANT、REVOKE)

1.DDL:数据定义语言

作用:用于创建数据库对象,如库、表、索引等

create——创建
drop——删除
alter——常用于对现有数据库元素进行修改

1.1 创建新的数据库

CREATE DATABASE 数据库名;

例:

create database blue;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-txDwXDUE-1689066431256)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711143913987.png)]

1.2 创建新的表

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。

示例:

create database blue;
use blue;
create table summer (id int NOT NULL,name char(10) NOT NULL,score decimal(5,2),passwwd char(48) DEFAULT' ',PRIMARY KEY (id));
desc summer;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XpBYhpJu-1689066431257)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711145012365.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uv6bJEIW-1689066431257)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711145022284.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ypcosma5-1689066431257)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711144823398.png)]

注:

NOT NULL 不允许为空值
DEFAULT’ ’ 默认值为空

PRIMARY KEY :主键一般选择没有重复并且不为空值的字段

1.3 删除指定的数据表

drop

方法一:

use 数据库名
DROP TABLE 表名

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uoYlonYz-1689066431258)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711145719610.png)]

方法二:

DROP TABLE [数据库名.] 表名;
#如不用USE进入库中,则需加上数据库名

示例:

use qqbb;
create table ffbb (id int NOT NULL,name char(10) NOT NULL,score decimal(5,2),passwwd char(48) DEFAULFAULT' ',PRIMARY KEY (id));
desc ffbb;
drop table qqbb.ffbb;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4ymxgVFv-1689066431258)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711150734302.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-M3luzFZL-1689066431258)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711150745945.png)]

1.4 删除指定的数据库

DROP DATABASE 数据库名;

示例:

drop database zz;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jXGfIFEg-1689066431259)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711151017981.png)]

2.DML管理表中的数据记录

作用:数据操纵语言,用于对表中的数据进行管理,用来插入、删除和修改数据库中的数据

insert ——插入
update——修改、更新数据表中的数据记录
delete——删除

2.1 INSERT在表中插入数据

(1)格式:

INSERT INTO 表名(字段1,字段2[,...]) VALUES (字段1的值,字段2的值,...);
SELECT * FROM zzz ;      #查询表的数据记录

(2)示例:

INSERT INTO summer (id,name,score,password) values(1,'zhangsan',70.5,PASS0.5,PASSWORD('123456'));

INSERT INTO summer (id,name,score,password) values(2,'lisi',90,PASSWORD(' '));

insert into summer (id,name,score) values(3,'cc',88.50);

select * from summer;

insert into summer values(4,'zjf',100,123456,null);

注:

PASSWORD(‘123456’):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。
在这里插入图片描述

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JNlnAsTZ-1689066431260)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711163245818.png)]

2.2 修改、更新数据表中的数据记录

(1)格式:

UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];

(2)示例:

update summer set name='txbb' where id=3;
update summer set score='100' where id=3;
update summer set password=password('123') where name='txbb';

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lb5V85KT-1689066431260)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711160439130.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UZPYNeM6-1689066431260)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711160504937.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AELuqc57-1689066431261)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711163427904.png)]

2.3 在数据表中删除指定的数据记录

(1) 格式:

DELETE FROM 表名 [WHERE 条件表达式];

(2)示例:

delete from summer where id=4

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FHpPsT2i-1689066431261)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711163819052.png)]

3.DQL查询数据记录

select

(1)格式

SELECT 字段名1,字段名2[,...] FROM 表名[WHERE 条件表达式];

(2)示例:

#查询数据表信息
SELECT * FROM summer;
SELECT id,name,score FROM summer WHERE id=2;
#以列表方式竖向显示
select name from summer\G 
#只显示头2行
select * from summer limit 2;
#显示第2行后的前3行
select * from summer limit 2,3;     

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9kssJRPX-1689066431261)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711164543629.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CQOwcPbF-1689066431262)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711164612686.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Qfd3mdC3-1689066431262)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711164746722.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uK41Jwi0-1689066431262)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711165235707.png)]

4.DCL 数据控制语言

用于设置或者更改数据库用户或角色权限(数据控制语句,用于控制不同数据段直接的许可和访问级别的语句,这些语句定义了数据库、表、字段、用户的访问权限和安全级别,如COMMIT、ROLLBACK、GRANT、REVOKE)

4.1 修改表名和表结构

(1)格式:

ALTER TABLE 旧表名 RENAME 新表名;

(2)示例:

alter table summer rename tree;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vE7r5hKF-1689066431263)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711165716047.png)]

4.2 扩展表结构(增加字段)

(1)格式

ALTER TABLE 表名 ADD address varchar(50) default '地址不详';
#default '地址不详':表示此字段设置默认值为地址不详,可与NOT NULL配合使用

(2)示例:

alter table tree add address varchar(50) default'地址不详';

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-f7LpkkGZ-1689066431263)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711170345222.png)]

4.3 修改字段(列)名,添加唯一键

ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];
unique key:唯一键(特性:唯一,但可以为空,空值只允许出现一次)
Primary key:唯一且非空(主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。)
ALTER TABLE tree CHANGE name user_name varchar(10) unique key;

在这里插入图片描述

#CHANGE可修改字段名、数据类型、约束等所有项。

ALTER TABLE 表名 modify column 字段名 类型。
数据库中表 字段是varchar(30),修改类型可以用(谨慎修改类型,可能会导致原有数据出错)

4.4 删除字段

格式:

ALTER TABLE 表名 DROP 字段名;

示例:

alter table summer drop season;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uXlWYoBZ-1689066431264)(C:\Users\zhao\AppData\Roaming\Typora\typora-user-images\image-20230711170113312.png)]

drop删除和delete删除的区别
delete 和 drop 都是常用于删除数据的 SQL 关键字,它们的主要区别在于:

  • 功能不同
    delete 用于从表中删除行或数据,其中可以根据特定条件删除选定的行或数据。delete 会将数据装入事务日志,并且能够回退操作。删除后还可以进行 rollback 操作,将删除的数据重新插入到表中。
    drop 用于删除整张表,也可以删除其他数据库对象,例如视图或索引。drop 操作是不可恢复的,也就是说,删除了对象就无法再恢复,因此在使用 drop 命令时应谨慎操作。
  • 执行速度和效率不同
    由于不同的操作方式, delete 和 drop 对数据库性能和效率的影响也不同。
    delete 执行速度较慢,因为它需要遍历整个表来查找要删除的行
    drop 执行速度较快,因为它仅需要删除表和表的元数据,不会对表数据进行查找或删除。
    因此,如果您只需要删除几行记录,可以使用 delete,但是如果您要删除整张表或其他数据库对象,则应该使用 drop。

总之,delete 和 drop 都是一些常见的 SQL 关键字,对于使用它们进行数据操作时,应当根据具体情况选择合适的方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/744964.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于虚拟机kali系统忘记密码修改密码的操作

1、启动kali虚拟机,进入GRUB菜单,选中kali GNU/Linux 按e 进入编辑状态 2、在编码文档里找到linux ...root....quiet 3、在末尾添加 rw single init/bin/bash single --进入单用户模式 rw --根分区的挂载模式默认是只读(ro),…

最全整理,web自动化测试框架总结-实战案例,从0精通封装...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 web自动化测试框架…

第2讲 KMD ISP子系统缩略词及目录结构

QCOM Camera子系统缩略词介绍 CPAS(Camera Peripherals and Support)CDM(Camera Data Mover)TFE(Thin Front End)IFE(Image Front End)OPE(Offline Processing Engine)BPS(Bayer Processing Segment)SFE(Sensor Front End)LRME(Low Resolution Motion Estimation)CSID(Camera …

【《快捷学习Spring》——带你步入Spring世界的快速、有趣、实用之旅!】

本书是一本学习Spring 框架的入门书籍,引导读者逐步上手,书中提供了所有必要的理论 知识,通过实例讨论实际应用程序的主题。本书分为两部分。第I部分是基础(1~6章),学习 使用支持Spring框架的基本组件。分别讨论了真实世界里的Spr…

Js语法学习实战 -数据类型

Js语法学习实战 -数据类型 1. undefined2. null3. Boolean4. Number5. String5.1 常用方法5.2 字符串迭代遍历方法 6. Symbol类型7. Object7.1 基本使用7.2 对象遍历7.3 复制对象方法 8. 数组 - Array8.1 数组的常用方法8.2 数组遍历 9. Function JS语法学习实战系列合集 javas…

6-Spring cloud之Hystrix容错处理(上)

6-Spring cloud之Hystrix容错处理(上) 1. 前言1.1 关于雪崩1.1.1 什么是灾难性雪崩1.1.2 服务雪崩形成的原因1.1.3 如何防止灾难性雪崩效应 1.2 前文介绍 2. Hystrix容错处理2.1 项目搭建(Ribbon整合Hystrix)2.1.1 项目结构2.1.2 …

IOI车机系统刷机和改包笔记

前言 我自己21年买的雪佛兰探界者SUV,没想到到了23年,车机系统上的高德导航还是3.2版本,而官方的已经7.1. 中间出去玩,在高速上被车机上的高德坑了好多次,简直无力吐槽。单纯使用手机Carplay虽然也能完成导航任务&am…

2023年上半年鲁大师电动车综合分数榜解读:九号M95C荣登榜首

2023年上半年电动车综合分数榜单显示了电动车市场的最新发展趋势和品牌表现。 九号M95C获得了第一名,得分798分。九号M95C以其卓越的性能和创新设计脱颖而出。它的高得分主要来自于其强大的续航能力、高速性能和可靠性。九号M95C在电动单车市场中取得了非常好的口碑…

23款奔驰C260L加装原厂香氛负离子系统,清香宜人,久闻不腻

奔驰原厂香氛合理性可通过车内空气调节组件营造芳香四溢的怡人氛围。通过更换手套箱内香氛喷雾发生器所用的香水瓶,可轻松选择其他香氛。香氛的浓度和持续时间可调。淡雅的香氛缓缓喷出,并且在关闭后能够立刻散去。车内气味不会永久改变,香氛…

IPv6 地址简介

IP 地址是指互联网协议地址,它是允许设备连接到互联网的标识符。互联网协议版本 6 (IPv6) 地址是一个 128 位字母数字标签,用于标识和定位计算机网络中的网络接口卡 (NIC) 或网络节点。 IPv6由互联网工程任…

C# 圆盘(hsv)颜色选择器

【首先贴上github链接:适用于 Windows 窗体的 Cyotek 拾色器控件】 一、简单使用教程 此处是我使用Cyotek.Windows.Forms.ColorPickers库部分功能的一些经验和思路总结,没有太多深入地去学习,如果有哪位大佬有深入学习使用的话,可…

阿里云限时福利:WoSign品牌SSL证书首购4折优惠

阿里云限时福利:WoSign品牌SSL证书首购4折优惠 阿里云SSL证书限时首购福利:2023年07月04日至08月31日,阿里云平台WoSign品牌系列SSL证书首购4折优惠,惊喜折扣、限时促销、限量抢购,机会不容错过! 阿里云平…

PCB防静电设计的必要性

平时通过走路穿衣等日常活动带来的摩擦,会产生不同幅值的静电电压,但其能量很小不会对人体产生伤害,不过对于电子元器件来说,这种静电能量却是不能忽视的。 在干燥的环境下,人体静电(ESD)的电压很容易超过6~35Kv&#…

Ubuntu 22安装使用Codon高性能Python编译器记录

Ubuntu 22安装使用Codon高性能Python编译器记录 Codon 在官方 Ubuntu 存储库中没有直接的教程,但可以尝试如下方法进行安装。 一、更新系统 终端输入: sudo apt update以及 sudo apt upgrade二、安装curl 输入指令: sudo apt install …

DHCP静态分配IP地址、IP-MAC绑定、静态ARP有哪些区别?

DHCP静态分配IP地址、IP-MAC绑定、静态ARP这三个功能都涉及到IP地址和MAC地址的对应关系,但其应用场景及实现的功能有所不同,如表所示: 原文地址https://support.huawei.com/enterprise/zh/knowledge/EKB1000052241

Linux下如何部署Nuxt项目(通过ip直接访问)

一、基础环境准备 1.确定服务器的Linux的系统版本 cat /etc/issue 不要问为什么,问就是吃过大亏 2.确定 node mysql是否安装,版本尽量与本地开发环境一致 如果没有安装建议自己百度一下,要根据Linux系统及版本来进行安装; 二、…

企业信息化-亿发软件,中小企业数字化转型解决方案供应商

因自身规模和企业性质,中小型企业需要有效管理企业资源,因此企业信息化管理至关重要。在此背景下,为中小企业量身定制的信息化管理系统可以为中小型企业带来显著的效益。能够实现数据的迅速整合,便于跨部门的协调和管理&#xff0…

计算机网络|思维导图|自顶向下方法|MindMaps资料分享

前言 那么这里博主先安利一下一些干货满满的专栏啦! 手撕数据结构https://blog.csdn.net/yu_cblog/category_11490888.html?spm1001.2014.3001.5482这里包含了博主很多的数据结构学习上的总结,每一篇都是超级用心编写的,有兴趣的伙伴们都支…

【JMeter】同步定时器Synchronizing Timer集合点功能

LoadRunner 中有一个可以设置集合点的功能,顾名思义是设置多个虚拟用户等待到一个时间点,都到齐集合后一起发请求达到并发的目的 集合点是什么意思呢? 阻塞线程,直到指定的线程数量到达后,再一起释放,可以…

【Leetcode】206. 反转链表

题意:反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 一开始需要 cur head pre None 第二步反转指针 cur.next pre 接着再继续移动指针 tmp cur.next // 放在反转之前 pre cur cur tmp 完整…