mysql笔记3(数据库、表和数据的基础操作)

news2024/9/22 17:36:43

文章目录

  • 一、数据库的基础操作
    • 1. 显示所有的仓库(数据库)
    • 2. 创建数据库
      • 注意(命名规范):
    • 3. 删除数据库
    • 4. 查看创建数据库的SQL
    • 5. 创建数据库时跟随字符编码
    • 6. 修改数据库的字符编码
  • 二、表的基础操作
    • 1. 引入表的思维
    • 2. 引用数据库
      • 3. 查看该数据库下面的表
      • 4. 创建表
        • ① 初级
          • 上述name varchar(30)中30是字符宽度或者说最大字符串长度的限制。实际输入的数据是可以超过这个宽度的,那么超过这个宽度会有什么后果?
        • ② 高级(企业在用)
      • 5. 查看表结构
        • ① show create table 表名;(优点:会显示创建这张表时的sql语句)
        • ② desc 表名;(优点:直观、好看)
      • 6. 删除表
      • 7. 修改表
        • ① 添加字段
        • ② 删除字段
        • ③ 更改字段
        • ④ 修改表名
  • 三、数据的基础操作
    • 1. 插入数据(实际开发过程中不是这样的,但是我们要会这种写法)
    • 2. 查看表内数据(基本)
    • 3. 更新表内数据
    • 4. 删除表内数据
    • 5. 清空表
      • ① delete from 表名(不推荐:因为它在删除时会遍历整张表,效率非常低)
      • ② truncate table 表名(直接销毁这张表,销毁完再创建一张一模一样的表,只是表内的数据已经不在了)
  • 四、SQL语句区分
  • 五、字符集编码问题
  • 六、内容出处

一、数据库的基础操作

CRUD:create、drop、alter、show

1. 显示所有的仓库(数据库)

show databases;
在这里插入图片描述
information-schema:存储服务器管理数据库的信息
mysql:提供一些系统的信息,例如:root用户名及密码
performance_schema:存储服务器性能信息
sys:系统文件
test(有的版本没有):测试库
注:
其它的库是我自己建的

2. 创建数据库

一、普通创建:
① create database + 数据库名;
二、如果该数据库已存在就不创建,反之创建(就算该数据库已经存在也能通过,只是会弹出警告):
② create database if not exists + 数据库名;
③ create database if not exists + 数据库名(数据库名写在反引号里);
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

注意(命名规范):

        不能用关键字(如create、database等)作为数据库名、表名、表中的字段名。如果非要用,就得给它们加上反引号。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
        后续创建和删除普通的数据库(不以关键字作为数据库名)时给数据库名加上反引号可以使代码看起来更高级。

3. 删除数据库

一、普通删除:
① drop database + 数据库名;
二、如果该数据库已存在就不创建,反之创建(就算该数据库已经存在也能通过,只是会弹出警告):
② drop database if exists + 数据库名;
③ drop database if exists + 数据库名(数据库名写在反引号里);
注:
删除一个不存在的数据库会报1008错误。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. 查看创建数据库的SQL

看一下当时是怎么创建的这些数据库的:
show create database + 数据库名;
在这里插入图片描述

5. 创建数据库时跟随字符编码

① create database if not exists student charset=gbk;
② create database if not exists teacher charset=utf8;
在这里插入图片描述
注:
① 常用的字符编码:GBK(中文简体)、utf8(国际通用)
② 乱码和字符编码有关
③ cmd的字符编码时gbk,因此可以显示中文
④ 在windows上学习时字符编码可以选择gbk(因为cmd就是gbk),但是在linux、mac上学习时要选择utf8。实际开发过程中也要选择utf8,因为上传到服务器以后大多数人用的都是utf8。

6. 修改数据库的字符编码

alter database + 数据库名 + charset=改成哪种字符编码
在这里插入图片描述

二、表的基础操作

CRUD:create(创建表)和alter+add(增加表内字段)、drop(删除表)和alter+drop(删除表内字段)、alter、show和desc

1. 引入表的思维

仓库 -> 数据库
货架 -> 表
物品放在货架上 -> 数据放在表里

2. 引用数据库

可以理解为指定某仓库发货:
use + 数据库名
在这里插入图片描述

3. 查看该数据库下面的表

可以理解为查看某仓库的所有货架:
show tables;
在这里插入图片描述

4. 创建表

① 初级

在这里插入图片描述
在这里插入图片描述

上述name varchar(30)中30是字符宽度或者说最大字符串长度的限制。实际输入的数据是可以超过这个宽度的,那么超过这个宽度会有什么后果?

等后面再来看这个问题。

② 高级(企业在用)

在这里插入图片描述
在这里插入图片描述
auto_increment:自动增长
primary key:主键(主键不可以为空) 写上了这个意味着该字段的数据是唯一的(每个学生的学号不可能重复,靠它来区分学生)关系型数据库的实现也依靠主键
comment:注释(后面的引号是普通的单引号,不是反引号,用反引号会报1064错误)
not null:意思是该字段不能为空
default:默认值
engine=innodb:数据库引擎是innodb。现在mysql里用的最多的数据库引擎就是innodb

5. 查看表结构

① show create table 表名;(优点:会显示创建这张表时的sql语句)

在这里插入图片描述

② desc 表名;(优点:直观、好看)

在这里插入图片描述
PRI:primary key缩写
extra:额外的规则(限制)

6. 删除表

① drop table 表名;
② drop table if exists 表名;
③ drop table if exists 表名(表名用反引号引起来);
④ 同时删除多张表:drop table if exists 表名, 表名, 表名;
在这里插入图片描述
注:
① 删除不存在的表会报1051错误
不可以同时删掉多个数据库
在这里插入图片描述

7. 修改表

① 添加字段

① 普通添加:alter table 表名 add 字段名 字段类型;
在这里插入图片描述
② 在指定位置添加:
alter table 表名 add 字段名 字段类型 after 字段名(想放在哪个字段后面)
在这里插入图片描述
没有before这个语法
在这里插入图片描述
③ 直接在开头添加:
alter tabel 表名 add 字段名 字段类型 first;
在这里插入图片描述

② 删除字段

alter table 表名 drop 字段名;
在这里插入图片描述

③ 更改字段

alter table 表名 change 要改的字段名 改成什么
在这里插入图片描述
在这里插入图片描述
只修改字段的类型:
alter table 表名 modify 要改的字段名 改成什么类型
在这里插入图片描述

④ 修改表名

alter table 表名 rename to 改成什么名;
在这里插入图片描述

三、数据的基础操作

CRUD:insert、delete、update、select

1. 插入数据(实际开发过程中不是这样的,但是我们要会这种写法)

① insert into 表名 (字段, 字段) values ( 对应的数据, 对应的数据)
表名后面的字段不省略时:字段顺序可以不与建表时的字段顺序一致,只需要让此处的字段顺序与values后面的数据顺序一致即可
② insert into 表名 values (对应的数据, 对应的数据)
表名后面的字段省略时:values后面的数据顺序必须与建表时的字段顺序一致
③ 一次插入多条数据(直接在values后面补充数据即可,数据之间以逗号隔开):
insert into 表名 (字段, 字段) values ( 对应的数据, 对应的数据), ( 对应的数据, 对应的数据);
insert into 表名 values (对应的数据, 对应的数据), ( 对应的数据, 对应的数据);
在这里插入图片描述
在这里插入图片描述
上面的引号都是普通的单引号

2. 查看表内数据(基本)

其实CRUD中查询是最难的

① select 要查的字段 from 查哪张表里
② 查看某张表里的全部字段(效率不高,性能方面存在缺陷):select * from 表名;
在这里插入图片描述

3. 更新表内数据

① 重点在于根据谁去改,改什么。
② 可以一次改多个字段
③ 一定要注意, where后面的条件, SQL注入攻击就跟它有关

① update 表名 set 字段名=改成什么 where 要改谁
② update 表名 set 字段名=改成什么, 字段名=改成什么 where 要改谁 or 要改谁
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. 删除表内数据

一定要特别注意where后面的条件

delete from 表名 where 要改谁
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. 清空表

① delete from 表名(不推荐:因为它在删除时会遍历整张表,效率非常低)

        我们可以发现,除非我们特意指定id,否则新插入的数据id会承接该表销毁之前的id序号。在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

② truncate table 表名(直接销毁这张表,销毁完再创建一张一模一样的表,只是表内的数据已经不在了)

        我们可以发现用此种方式清空表后,重新插入数据的id是从1开始的
在这里插入图片描述
在这里插入图片描述

四、SQL语句区分

        数据库无非就是增删改查。我们可以发现数据库、表和数据这三个东西的增删改查都不一样。

① DDL(全称:data definition language, 数据库定义语言):就是给数据库用的语言 – 对数据库而言
CRUD:create、drop、alter、show
② DML(全称:data manipulation language, 数据操纵语言):–对数据而言
CRUD:insert delete update select
③ DCL(全称:data control language, 数据库控制语言):控制不同用户对数据库中表的开发权限

五、字符集编码问题

查看字符集编码:show variables like ‘character_set_%’;
在这里插入图片描述
① 由于character_set_client(终端) character_set_results(返回值) 都是gbk,因此上述数据可以用中文输入。
② 如果其它平台想用中文输入,把character_set_client和character_set_results改成gbk即可。
命令:set character_set_client=gbk;
实际开发过程中一定是utf8,符合国际标准。这也是为什么windows相对而言没那么适合做开发,不过微软这些年一直在方便开发者的工作而努力。

六、内容出处

mysql

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

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

相关文章

终端安全如何防护?一文为你揭晓答案!

终端安全防护是确保组织内部网络及其连接设备免受威胁的关键措施。 以下是终端安全防护的一些核心方法: 1. 资产管理与识别 摸清家底:识别所有连接到网络的终端设备及其状态,包括硬件和软件配置。 资产分类:确定哪些资产最为关…

华三(H3C)HDM服务器硬件监控指标解读

在当今日益复杂的IT环境中,服务器的稳定运行对于保障业务的连续性至关重要。华三(H3C)作为知名的网络设备供应商,其HDM(Hardware Diagnostic Module)技术为服务器硬件的监控提供了强有力的支持。监控易作为…

如何使用SSHFS通过SSH挂载远程文件系统?

SHFS(SSH 文件系统)是一款功能强大的工具,它允许用户通过 SSH 挂载远程文件系统,从而提供一种安全便捷的方式来访问远程文件,就像访问本地文件一样。本文将引导您完成使用 SSHFS 挂载远程文件系统的过程,为…

【自动化与控制系统】SCI一区TOP神刊!最快19天accept、稳定检索!

期刊解析 🚩本 期 期 刊 看 点 🚩 国人发文占比第一,TOP刊 审稿友好,审稿速度快 自引率9.8% 今天小编带来计算机领域SCI快刊的解读! 如有相关领域作者有意投稿,可作为重点关注! 01 期刊信息…

pytlsd在Win10下编译与使用

下载pytlsd项目,GitHub - iago-suarez/pytlsd: Python transparent bindings for LSD (Line Segment Detector) CMake配置 Windows 10,Visual Studio 2019下编译 Release版本生成文件包括: 测试代码: # -*- coding: utf-8 -*- import cv2 import matplotlib.pyplot as p…

CATH数据库数据下载

CATH数据库提供了多种类型的数据供用户下载,涵盖了蛋白质的结构域分类、同源性分析、功能注释等方面。以下是CATH数据库提供的一些主要数据类型及其解释: http://www.cathdb.info/download 1. 分类数据(Classification Data) 文件:如cath-domain-list.txt内容:包含CATH数…

jvm的各种性能检测工具

1: jvm 的性能诊断工具 1.1.:Jstat 这个的全称是JVM Statistics Monitoring Tool,说白了就是统计jvm的各种指标的,我们这边主要关注内存使用指标,一般我们后面要跟上pid的进程 jstat -gc pid jstat -gcutil pid最终的这些结果命…

教师节特辑:AI绘制的卡通人物,致敬最可爱的人‍

【编号:9】教师节到了,今天我要分享一组由AI绘制的教师节主题卡通人物插画,每一幅都充满了对老师的敬意和爱戴。让我们一起用这些可爱的卡通形象,向辛勤的园丁们致敬! 🎓【教师形象】 这…

ES6标准-【一】【学习ES6看这一篇就够了!!】

目录 顶层对象的属性 ES5中的顶层对象 ES6中的顶层对象 数组的解构赋值 默认值 对象的解构赋值 默认值 注意点: 字符串的解构赋值 数值和布尔值的解构赋值 函数参数的解构赋值 ES6中的圆括号问题 不能使用圆括号的情况 变量声明语句 函数参数 赋值语…

【JS】深拷贝与浅拷贝

深拷贝与浅拷贝 浅拷贝实现浅拷贝的方法扩展运算符 深拷贝实现深拷贝的方法递归JSON.parse(JSON.stringify()) 深拷贝和浅拷贝都是处理对象或数据的复制操作 浅拷贝 浅拷贝创建一个的对象,复制的是原对象的引用新对象与原对象共用一个相同的内存地址,因…

分布式算法-Paxos、Raft、ZAB复习

目录 1. Paxos算法 1.1 算法流程 1.2 接受者选举规则 2. Raft算法 2.1 Leader选举 2.2 安全性 3. ZAB算法 3.1 ZAB协议介绍 3.2 消息广播 3.3 崩溃恢复 3.4 数据同步 1. Paxos算法 Paxos 算法是 Leslie Lamport 在 1990 年提出的,经典且完备的分布式一致…

docker的镜像制作

镜像的加载原理 docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFS UnionFS(联合文件系统): Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改…

Delphi 12.1安卓APP开发中获取硬件信息及手机号

Demo与代码已上传到CSDN下载。 这里简单说一下代码内容,完整代码请自行下载,不清楚的欢迎留言交流。 前言 演示Demo使用了我自己开发的一个控件,TLayoutPro 《Delphi D10.3 LayoutsPro 控件简介 -避免输入焦点被虚拟键盘遮挡》请查看并下载控…

第三部分:3---环境变量

目录 什么是环境变量? PATH环境变量: 临时修改环境变量PATH: HOME环境变量: 可能使用环境变量的场景: 进程和环境变量的关系: 环境变量相关操作: 代码获取环境变量: 主函数传…

百度静态资源瓦片nginx直接显示完整案例

案例地址:https://download.csdn.net/download/jinhuding/89733763 访问显示效果:(根据瓦片地址直接显示) http://172.16.39.203:8099/tiles/

(rs系列)rs4之补环境

网站:aHR0cDovL3d3dy5mYW5nZGkuY29tLmNuLw 先讲讲rs4特征​: 1、打开控制台立刻进入无限debugger,混淆代码格式_$xx 会有两次无限debugger,直接在对应位置鼠标右键》Never pause here即可​。当然这种方法比较耗资源,也…

代码随想录算法训练营第42天|188. 买卖股票的最佳时机 IV、714. 买卖股票的最佳时机含手续费

目录 188. 买卖股票的最佳时机 IV(交易最多k次)1、题目描述2、思路3、code4、复杂度分析 714. 买卖股票的最佳时机含手续费1、题目描述2、思路3、code4、复杂度分析 309. 买卖股票的最佳时机含冷冻期1、题目描述2、思路3、code4、复杂度分析 买卖股票习题…

智能语音交互:人工智能如何改变我们的沟通方式?

在科技飞速发展的今天,人工智能(AI)已经渗透到我们生活的方方面面。其中,智能语音交互作为AI技术的一个重要分支,正以前所未有的速度改变着我们的沟通方式。从智能家居的控制到办公自动化的应用,再到日常交…

CentOs7 解决yum更新源报错:[Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。

CentOs7 解决yum更新源报错:[Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。 前言问题解决方法: 前言 遇到这个问题大概率是镜像源的问题可以参照这篇文章的内容试一下 镜像源问题相关解决方法 根据自己的情况对症下药,如果还不…

WPS如何删除表格下的空白页

WPS Office(12.1.0.17827) ① 鼠标右键,选择段落 ② 行距:固定值;设置值:1磅;取消勾选,确定即可~