当前位置: 首页 > news >正文

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

文章目录

  • 一、数据库的基础操作
    • 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

相关文章:

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

文章目录 一、数据库的基础操作1. 显示所有的仓库(数据库)2. 创建数据库注意(命名规范): 3. 删除数据库4. 查看创建数据库的SQL5. 创建数据库时跟随字符编码6. 修改数据库的字符编码 二、表的基础操作1. 引入表的思维2. 引用数据库3. 查看该数据库下面的表4. 创建表…...

计算机毕业设计选题-基于python的企业人事管理系统【源码+文档+数据库】

💖🔥作者主页:毕设木哥 精彩专栏推荐订阅:在 下方专栏👇🏻👇🏻👇🏻👇🏻 实战项目 文章目录 实战项目 一、基于python的企业人事管理系…...

科研绘图系列:R语言折线图(linechart plots)

文章目录 介绍加载R包导入数据数据预处理画图组合图形介绍 在R语言中,折线图(Line Plot)是一种常用的数据可视化类型,用于展示数据随时间或有序类别变化的趋势。折线图通过连接数据点来形成一条或多条线,这些线条可以清晰地表示数据的变化方向、速度和模式。 加载R包 k…...

Opencv中的直方图(5)计算EMD距离的函数EMD()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 计算两个加权点配置之间的“最小工作量”距离。 该函数计算地球搬运工距离(Earth Mover’s Distance)和/或两个加权点配…...

KDD 2024 时空数据(Spatio-temporal) ADS论文总结

2024 KDD( ACM SIGKDD Conference on Knowledge Discovery and Data Mining, 知识发现和数据挖掘会议)在2024年8月25日-29日在西班牙巴塞罗那举行。 本文总结了KDD2024有关时空数据(Spatial-temporal) 的相关论文,如有疏漏,欢迎大…...

uniapp+vue3实现小程序和h5解压线上压缩包以及如何访问解压后的视频地址

安装jszip插件 npm install jszip 对应功能实现和逻辑处理&#xff1a; <script setup>import { onMounted, reactive, ref } from vueimport { onHide, onUnload } from dcloudio/uni-appimport JSZip from jsziplet videoSrc ref() // 视频地址// 创建JSZip实例con…...

探索 Zed 编辑器:速度与协作的巅峰之作

Zed 是一款备受瞩目的代码编辑器,专为现代开发者打造。本文将深入介绍 Zed 的独特优势,以及如何快速上手使用这款编辑器,助你在编程工作中大幅提升效率。 一:Zed 编辑器的优势 Zed 是近年来崭露头角的一款代码编辑器,迅速赢得了众多开发者的青睐。以下是 Zed 的几大核心优…...

文心快码前端工程师观点分享:人机协同新模式的探索之路(三)

本系列视频来自百度工程效能部的前端研发经理杨经纬&#xff0c;她在由开源中国主办的“AI编程革新研发效能”OSC源创会杭州站105期线下沙龙活动上&#xff0c;从一款文心快码&#xff08;Baidu Comate&#xff09;前端工程师的角度&#xff0c;分享了关于智能研发工具本身的研…...

Qt基础类03-直线类QLine

Qt基础类03-直线类QLine 摘要基本信息成员函数程序全貌QLine::QLine()QLine::QLine(const QPoint &p1, const QPoint &p2)QLine::QLine(int x1, int y1, int x2, int y2)QPoint QLine::p1() constQPoint QLine::p2() constint QLine::x1() constint QLine::x2() consti…...

集成电路学习:什么是ARM先进精简指令集计算机

ARM&#xff1a;先进精简指令集计算机 ARM先进精简指令集计算机&#xff08;Advanced RISC Machine&#xff0c;简称ARM&#xff09;是一种基于精简指令集计算机&#xff08;RISC&#xff09;原则的计算机处理器架构&#xff0c;由英国的ARM公司开发。这种架构以其低功耗和高性…...

设计模式-行为型模式-迭代器模式

1.迭代器模式的定义 迭代器模式提供一种对容器对象中的各个元素进行访问的方法&#xff0c;而不需要暴露该对象的内部细节&#xff1b; 在软件系统中&#xff0c;容器对象有两个职责&#xff1a;一是存储数据&#xff0c;二是遍历数据&#xff1b;从依赖性上看&#xff0c;前者…...

FRP代理(QUIC通信)实验

访问关系与TCP实验相同&#xff0c;配置不一样 服务端配置 客户端配置 通信数据...

项目依赖拉不下来卡着不动怎么办,node又不支持cnpm

如果你的项目依赖在拉取时卡住&#xff0c;可以尝试以下步骤来解决问题&#xff1a; 检查网络&#xff1a;确保你的网络连接稳定。如果可能&#xff0c;尝试使用 VPN 或更换网络。 使用镜像源&#xff1a; 对于 yarn&#xff0c;可以使用淘宝镜像&#xff1a; yarn confi…...

ansible--role

简介 roles是ansible&#xff0c;playbooks的目录的组织结构&#xff0c;将代码或文件进行模块化&#xff0c;成为roles的文件目录组织结构。 易读&#xff0c;代码可冲哟美好&#xff0c;层次清晰 目录机构 mkdir roles/nginx/{files,handlers,tasks,templates,vars} -ptou…...

SpinalHDL之数据类型(一)

本文作为SpinalHDL学习笔记第五十四篇,介绍SpinalHDL的Bool数据类型。 SpinalHDL技术交流QQ群: Note: 1.本群是个人技术交流群,不是什么官方答疑群; 2.提问是你的权利,但回答不是别人的义务; 3.可以潜水,不能灌水; 4.请文明交流,做这行的都算高层次人才,希望你…...

Ansys Zemax | 什么是Sobol取样?

附件下载 联系工作人员获取附件 本文主要介绍了&#xff1a; 什么是Sobol取样&#xff1f; 和随机光线产生方法相比&#xff0c;Sobol取样有什么优点&#xff1f; Sobol取样有什么限制&#xff1f; 随机取样和Sobol取样模式 一个光源会在位置空间以及角度空间随机产生光…...

Unity 热更 之 【YooAsset 热更】Unity 可以进行热更的资源管理系统,并 【Android 端简单实现·案例热更】

Unity 热更 之 【YooAsset 热更】Unity 可以进行热更的资源管理系统&#xff0c;并 【Android 端简单实现案例热更】 目录 Unity 热更 之 【YooAsset 热更】Unity 可以进行热更的资源管理系统&#xff0c;并 【Android 端简单实现案例热更】 一、简单介绍 二、YooAsset 引…...

vue3写一个无限树形菜单,递归组件

原本使用element plus的el-tree&#xff0c;可是他的UI不匹配&#xff0c;狠难改成自己想要的&#xff0c;所以只能自己去写一个&#xff0c;做法&#xff1a;使用递归组件 效果 组件代码itemDir.vue // itemDir.vue<template><div><ul v-for"node in li…...

3D建模主要使用哪些软件?有什么特点?

3D建模主要使用的软件多种多样&#xff0c;每种软件都有其独特的优势和适用领域。以下是一些主流的3D建模软件&#xff1a; 1. Autodesk 3ds Max 概述&#xff1a;3ds Max是一款功能丰富的建模和动画软件&#xff0c;广泛用于电影、游戏和虚拟现实等领域。 特点&#xff1a;…...

Android Studio 加载多个FLutter项目

按顺序操作即可 选择工程 选择Modules, 导入 module 选中创建module 选择要导入的目录&#xff0c;只选择主目录&#xff0c;下面的文件不要选 添加完成&#xff0c;点击ok后&#xff0c;会进行导入 最终导入成功...

智慧医疗能源事业线深度画像分析(上)

引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

微信小程序之bind和catch

这两个呢&#xff0c;都是绑定事件用的&#xff0c;具体使用有些小区别。 官方文档&#xff1a; 事件冒泡处理不同 bind&#xff1a;绑定的事件会向上冒泡&#xff0c;即触发当前组件的事件后&#xff0c;还会继续触发父组件的相同事件。例如&#xff0c;有一个子视图绑定了b…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

JVM垃圾回收机制全解析

Java虚拟机&#xff08;JVM&#xff09;中的垃圾收集器&#xff08;Garbage Collector&#xff0c;简称GC&#xff09;是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象&#xff0c;从而释放内存空间&#xff0c;避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...

大语言模型如何处理长文本?常用文本分割技术详解

为什么需要文本分割? 引言:为什么需要文本分割?一、基础文本分割方法1. 按段落分割(Paragraph Splitting)2. 按句子分割(Sentence Splitting)二、高级文本分割策略3. 重叠分割(Sliding Window)4. 递归分割(Recursive Splitting)三、生产级工具推荐5. 使用LangChain的…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

[Java恶补day16] 238.除自身以外数组的乘积

给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&#xff0c;且在 O(n) 时间复杂度…...

【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统

目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索&#xff08;基于物理空间 广播范围&#xff09;2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...

laravel8+vue3.0+element-plus搭建方法

创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

人工智能(大型语言模型 LLMs)对不同学科的影响以及由此产生的新学习方式

今天是关于AI如何在教学中增强学生的学习体验&#xff0c;我把重要信息标红了。人文学科的价值被低估了 ⬇️ 转型与必要性 人工智能正在深刻地改变教育&#xff0c;这并非炒作&#xff0c;而是已经发生的巨大变革。教育机构和教育者不能忽视它&#xff0c;试图简单地禁止学生使…...