初识MySql数据库

news2024/12/23 5:10:34

   ​​​​使用MySql数据库的英文打字小游戏:

英文打字小游戏

                              MySql学习

1:MySql是关系型数据库,跨平台的。Sql Server是微软出的啊。

2:Web服务器端运行原理图。

ed3827bc27ff41f7a689bfe2289b88cf.png

 Web服务器:网页资源的获取

游戏服务器:游戏数据的同步,账号的登录。

IP地址:电脑与电脑之间通信就会通过IP地址查找到对方电脑的位置。通过IP地址定位电脑的位置。每一个网址都会有一个IP地址,这个IP地址的解析是自动的,通过IP就能找到电脑。一台电脑是有多个软件的,当你通过IP找到电脑,请求数据时,不但需要你的IP地址还需要对应申请数据的软件的端口号,这个端口号是操作系统分配的未被使用的端口号。访问网站时没有输入端口号是因为有默认端口号的嘞。

4:游戏服务器端

图同上,原理同上,游戏服务器,而已。

5:MySql的安装

MySql默认有一个超级管理员,root 。

6:MySql的启动

e8df74a71f6543f6919c04044277f006.png

f47817208fac493cba4dcc49922285d8.png
7:如何在MySql中存储数据?MySql下可以创建多个库 (数据库) databases

一个库中可以创建多个表 (表格) tables (直接将库理解为Excel,表理解为sheet也没问题)

8:什么是表?MySql中需要先定好表头,表头表示我们的表有哪些列,表里面的每一行都是我们存储的数据。

9:MySql的控制台

MySql的可视化窗口安装路径可以打开,小图标也可以。

a36e7e2259d140b1af3861402625299c.png
10:数据库的创建。数据库的名字是不区分大小写的。

4e47d4de89c44a5a8648dde8ae3be552.png
11:在MySql Workbench图形化的界面中进行的每一步,都会发送一个Sql命令或Sql语句。Sql语句是一个结构化查询语句(Structed Query Language) Sql语句不同的数据库是相同的,增删改查的命令通常是一样的,只有一些微小的区别。

 12:MySql的增删改查。表中有一行一行的数据嘛,我们怎么来区分两个账号是否是一样的嘞,就是通过主键来进行区分。每一行的主键都一定是不同的。

一个表必须有主键,一般创建一个表头id来作为主键的标识。并且只能有一个主键。主键不能为null(空值)。某一个字段定义为了自动增长那么他必须是主键。如果你给两个字段设置为主键那么,这两个主键的组合将作为一个新的主键,所以说只有一个主键。Unique的限制可以两条数据为null,但是不能在不为null是重复。
13:角色表的设计。一般情况下,数据库的表结构设计好之后就不允许更改了,所以说我们要将数据库的表结构设计得更加容易扩展。怎么设计角色的存储呢?在账号密码的表之外在创建一个表来存储角色信息。因为user与role表需要进行关联,这里就需要用到外键关联了:

d977eb6187b042c68414b011e61b159a.png

关联发起者的列设置的值必须在被关联的列中存在,不然提交会不成功,这里的外键关联也相当于一种限制,被关联者的列一定是主键所在的列哦!外键是允许为空的。

你修改表结构,修改的数据必须符合修改后的表结构,不然会报错。

14:表之间的关系。有一对多,多对一,多对多的关系。一对多或者多对一只需要通过外键就行。多对多的话就需要使用中间表来存储啦。在能做成一张表的情况下就用一张表就行啦。多张表的查询也是会消耗一定的性能的。

15:MySql中的数据类型

Varchar(length):字符串类型,length表示最大长度。

Int:整数。后面可以加括号限制位数,不写默认Int(11)。

Float:小数。

Date:日期。即使你写时间也会被自动省掉。

Date time:日期加时间

16:利用Sql语句对MySql进行增删改查。

Sql语句不区分大小写。

Help; 查看Sql语句的常用命令。

Show databases; 查看所有的数据库。

Show tables;查看所有的表格。查看表格需要选择数据库。

Use 数据库名;表示选择数据库。选择数据库之后就可以show tables;

Create database 数据库名;创建数据库。

Drop database 数据库名;删除数据库。

以上的命令严格来说不是Sql语句只是MySql内置的命令,下面的才是正宗的Sql语句。用数据库软件存储数据的原因就是查询嘎嘎快!

Sql语句忘了怎么办呢?你就在bench中修改一些数据,提交的时候你看它怎么写的就行啦!

创建表:Create table 表名 (

       列名 数据类型 限制1 限制2 限制3,

       列名 数据类型 限制,

       Primary key(列名)

);

限制:

auto_increment:自动增长。

Default 值:为字段设置默认值。

Not null:不为空。

Unique:独一无二。

 

Desc 表名;:查看表结构,有哪些字段,字段的类型,字段的限制等等。

Drop table 表名;删除表。

表中插入数据:Insert into 表名 (字段1,字段2,···) values (‘您要插入的值’,’您要插入的值’,···);

表中更新数据:update 表名 set 字段1 = 值1,字段2 = 值2 ,··· where 满足的条件; 满足条件的数据进行如上更改。Where如果省略不写代表将所有的数据进行如上的修改。

表中删除数据:delete from 表名 where 条件;不加条件删除所有数据。

查询语句:

Select 字段1 as 字段,字段2 as 字段,··· from 表名 where 条件1 and 条件2 order by 字段1,字段2,··· limit 数字;默认是从小到大排序的,在order by 的字段后面加上desc就可以实现从大到小排序了。排序字符串的话会逐个字母进行排序,如果相同就用默认排序。多个排序字段的话从左往右,依次用字段排序。加上as代表不用原来的字段名,而用新的字段名给查询到的结果命名,as可省略,as 字段可不写,代表用原来的表头。

 

 

Where条件:

  • :数字:>  <  =  >=  <=  <>:不等于

Where id <>1;

字符串:=  >  <  >=  <=  <>:不等于  != :不等于。

  • :逻辑操作

And:满足两个条件。

Or:满足一个条件即可。

Where条件1 or 条件2 and 条件3:可以理解为and 的优先级比较高。意思就是:where (条件1) or (条件2 and 条件3) 这种写法不推荐,这种情况推荐加上括号。

Is:is仅用于is null 或者is not null

Not:我们可以在一个查询条件之前加上not表示不满足此条件。

  • :范围判断

In():在in中的举例中查找,例如:where name in(‘Ad’, ‘aa’, ‘a’),表示在in中的字符串中查找。

Not in() 与上面相反。

Between a and b:例如:select * from users where id between 2 and 9;查询id在 [2,9] 之间的所有数据。

Not between:与上面相反。

Like:模糊查询。例如:select * from users where name like ‘A%’;  %代表一个或者多个字符串的啊!这条查询语句就表示查找name以A开头的数据。如果like ‘yyc’:就是直接查找name为yyc 的。

还有一个符号:_ 代表一个字符。select * from users where name like ‘A_____’ 我这里敲了5个下划线,代表以A开头,name长度为6的数据。

样例:

  • :select * from 表名; 表示查询该表中的所有数据。*代表查询的列,*代表所有列,所以是查询全部的数据。
  • :select * from 表名 limit 数字;查询数字这么多条数据。
  • :select * from 表名 limit 数字1,数字2;数字1代表跳过数字1这么多条数据开始查询,数字2代表查询多少条数据。一般用于做分页。

查询静态值:

Select ‘some thing’;

Select 1 + 1;

常用函数:

都可以加as 表头啊,下面就不写了。这些函数都可以用来做查询时的条件限定嘞。

Select now() as 表头; as 表头可省略,代表将查询出来的表头重新命名。查询当前的时间。带日期,带时间。

Select curdate(); 带日期不带时间。

Select curtime();带时间不带日期。

Select pi();查询圆周率。

Select mod(a, b); 查询a对b取模的结果。

Select sqrt(a); 求算数平方根。

Select round(a); 四舍五入,还可以有第二个参数,表示保留几位小数。

Select floor(a); 向下取整。

Select ceil(a); 向上取整。

Count():select count(*) from table; 可以查询整个表有多少行。Select count(column) from table; 可以查询表中的column列有多少有值的数据。

更过函数请参考:Sql函数参考文档。

运算操作:

*

+

-

/:得到小数。

Div:得到整数。

Mod:取余。

%:取余。

字符串的操作:

Select concat(str1, str2, ···); 连接多个字符串。不能使用加法运算。

Select left(str, num); 取字符串的前num位。

Select length(str); 取得字符串的长度。

Select reverse(str); 将str进行反转。

Select replace(str1, str2, str3); 将str1中str2子串替换为str3。

Select date_format(date, format);  例如:format:‘%y/%m/%d’,2004/1/1

%y表示年,%m表示月,%d表示天。很多啊,需要的话官方文档查就行。

去重操作:

在查询的字段的前面加上distinct就行。

数据库的恢复与备份:

80471d4cee0444608a0e887138d60c8a.png

 

 

  

 

 

可以用文本文档直接打开。数据导出的是一个一个的Sql语句。也阔以用这个来学习Sql语句。
导出之后可以在bench中将数据库删除了。然后根据数据库的备份来恢复数据库。

2b046f0f11ae41b3aaadd67b3be7e676.png

 

17:远程连接mysql数据库

Use mysql;

Select host, user from user;

然后将localhost改成%就可以实现远程连接数据库了。

记得更新一下:flush privileges;

18:创建mysql用户

Create user1 ‘用户名’ @’访问权限(localhost/%)’ indentified by ‘设置的密码’,user2···;

19:查看字符集:

Show variables like ‘%char%’;

 

 
  


这两个改成支持中文的编码模式,才能支持中文

f19daf6caac74bd69f554fbc7e3debed.png

 

 
  


首先将my.ini拷贝一份,然后向图片的下面这么做。完成后记得重启Sql server吧,打开任务管理器的方式:ctrl + shift + esc。

76d03d958ee34d11983a5ace422e0947.png

 

 

 

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

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

相关文章

WEB通讯技术。前端实现SSE长连接,nodejs+express搭建简单服务器,进行接口调试,通过curl请求数据

描述 长连接&#xff08;Keep-Alive&#xff09;是一种HTTP/1.1的持久连接技术&#xff0c;它允许客户端和服务器在一次TCP连接上进行多个HTTP请求和响应&#xff0c;而不必为每个请求/响应建立和断开一个新的连接。长连接有助于减少服务器的负载和提高性能。 长连接的HTTP请…

《Android性能优化》一次失败的启动速度优化

正文 在优化APP启动之前&#xff0c;我们首先需要知道&#xff0c;APP启动时究竟发生了什么&#xff0c;才能有的放矢的优化。 APP的启动过程 APP的启动过程就是指&#xff0c;在手机屏幕上点击某个APP的图标&#xff0c;到APP的首页显示在用户面前的过程。 一般APP的启动过…

Web自动化测试简介及web自动化测试实战交教程

一、认识web自动化测试 1.什么是自动化测试&#xff1f; 自动化测试的概念: 软件自动化测试就是通过测试工具或者其他手段&#xff0c;按照测试人员的预定计划对软件产品进行自动化测试&#xff0c;他是软件测试的一个重要组成部分&#xff0c;能够完成许多手工测试无法完成或…

Linux网络服务----ftp

文章目录 一 、什么是FTP1.1 Standard模式&#xff08;主动模式&#xff09;1.2 Passive模式&#xff08;被动模式&#xff09; 二 、FTP的作用及工作原理2.1 FTP的作用和模式以及通信方式2.2 FTP的工作原理 三、搭建和配置FTP服务3.1 设置匿名用户访问的FTP服务(最大权限)3.2 …

优化改进YOLOv5算法之添加Res2Net模块(超详细)

目录 1 Res2Net 2 YOLOv5中添加Res2Net block 2.1 common.py配置 2.2 yolo.py配置 2.3.3 创建添加Res2Net block模块的YOLOv5的yaml配置文件 1 Res2Net 关于代表性计算机视觉任务的进一步消融研究和实验结果&#xff0c;即目标检测&#xff0c;类激活 mapping和显著目标检…

设计模式:行为型模式 - 观察者模式

文章目录 1.概述2.结构3.案例实现4.优缺点5.使用场景6.JDK中提供的实现 1.概述 定义&#xff1a; 又被称为发布-订阅&#xff08;Publish/Subscribe&#xff09;模式&#xff0c;它定义了一种一对多的依赖关系&#xff0c;让多个观察者对象同时监听某一个主题对象。这个主题对…

GEE:图像表达式计算——ee.Image.expression()详解

作者: _养乐多_ 在遥感图像处理和分析中,图像的表达式计算是一种常见的操作。利用 Google Earth Engine(GEE)平台的强大功能,可以方便地进行基于图像的表达式计算,从而实现对图像进行灵活、高效的处理和分析。 本文将介绍 GEE 平台中的 ee.Image.expression() 函数及其参…

Linux的虚拟地址空间与文件描述符

虚拟地址空间与文件描述符 虚拟地址空间文件描述符 虚拟地址空间 文件描述符

SAS学习第9章:卡方检验之适和性检验与独立性检验

卡方检验就是统计样本的实际观测值与理论推断值之间的偏离程度&#xff0c;实际观测值与理论推断值之间的偏离程度就决定卡方值的大小&#xff0c;如果卡方值越大&#xff0c;二者偏差程度越大&#xff1b;反之&#xff0c;二者偏差越小&#xff1b;若两个值完全相等时&#xf…

在Windows10中安装WSL2(Ubuntu 22.04.2 LTS)

WSL1 和 WSL2 WSL 1 于 2016 首次发布&#xff0c;在 windows 系统中可以使用linux系统。 但是WSL1的缺点有&#xff1a; 文件 I/O 慢&#xff0c;尤其是在大量IO操作时&#xff0c;例如使用 git 克隆仓库&#xff1b;不支持内核程序&#xff1b; WSL 2 针对以上两个缺点进…

C. Nauuo and Cards(思维)

Problem - C - Codeforces Nauuo是一个喜欢玩纸牌的女孩。 —天&#xff0c;她在玩纸牌时发现牌被混入了一些空牌。 这里有n张编号为1到n的牌&#xff0c;并且它们被混入另外n张空牌中。她把这2n张牌堆起来并且从中取出n张。给定N& uuo手中的n张牌和余下的n张牌(按照从上到…

3天学会Pytest自动化测试框架,哭着都要给我看完

目录 【前言】 【什么是pytest】 【pytest的特点】 【pytest的使用方法】 【附加内容】 【总结】 【前言】 在软件开发过程中&#xff0c;自动化测试是提高软件质量和效率的重要手段之一。pytest作为Python编写的自动化测试框架&#xff0c;具有简单易用、灵活性强等优点…

<Linux>POSIX信号量

目录 什么是信号量 如何理解信号量的使用 基于环形队列的生产消费者模型 如上问题我们如何用编码保证 &#xff1f;(信号量) 编码&#xff1a; POSIX信号量和SystemV信号量作用相同&#xff0c;都是用于同步操作。POSIX可以用于线程同步。 信号量本质上就是一个计数器。 什…

TS数据类型

基本数据类型 null undefined number string boolean 对于基本数据类型&#xff0c;可以不写类型注解&#xff0c;ts能通过值来判断变量的类型 let nu null let un undefined let num 23 let str "sdfk" let isShow true引用数据类型 数组 写法1 let arr:…

iconik--AI智能媒体管理解决方案

ftrack于去年加入Backlight&#xff0c;旗下有Celtx, Iconik, Wildmoka, 和Zype。这些公司都为媒体、娱乐和视频领域的客户提供基于云的解决方案。 今天&#xff0c;我们就来隆重地介绍其中一款软件–iconik&#xff01;谷歌、VICE媒体、亚马逊旗下米高梅、Complex Networks和S…

【C++初阶】C++入门

⭐博客主页&#xff1a;️CS semi主页 ⭐欢迎关注&#xff1a;点赞收藏留言 ⭐系列专栏&#xff1a;C初阶 ⭐代码仓库&#xff1a;C初阶 家人们更新不易&#xff0c;你们的点赞和关注对我而言十分重要&#xff0c;友友们麻烦多多点赞&#xff0b;关注&#xff0c;你们的支持是我…

GMW协议

概述 回顾混淆电路的流程&#xff0c;一方生成加密真值表&#xff0c;另一方执行计算&#xff0c;门电路的输入通过主动发送和不经意传输索取实现&#xff0c;用这样的方式来达到多方计算中一些公平性。 那么是否可以让双方拥有更加对等的地位&#xff0c;让每个参与方都持有一…

华为OD机试真题(Java),数组合并(100%通过+复盘思路)

一、题目描述 现在有多组整数数组&#xff0c;需要将他们合并成一个新的数组。 合并规则从每个数组里按顺序取出固定长度的内容&#xff0c;合并到新的数组&#xff0c;取完的内容会删除掉。 如果改行不足固定长度&#xff0c;或者已经为空&#xff0c;则直接取出剩余部分的内…

Numpy从入门到精通——Numpy运算符|批处理

这个专栏名为《Numpy从入门到精通》&#xff0c;顾名思义&#xff0c;是记录自己学习numpy的学习过程&#xff0c;也方便自己之后复盘&#xff01;为深度学习的进一步学习奠定基础&#xff01;希望能给大家带来帮助&#xff0c;爱睡觉的咋祝您生活愉快&#xff01; 这一篇介绍《…

Android 项目编译 Gradle 配置说明

前言 Android 的Gradle版本更新换代还是很快的&#xff0c;更新换代除了功能上变得强大之外&#xff0c;还会出现很多意料之外的Bug&#xff0c;而很多开发者会被折磨的死去活来&#xff0c;下面我们来看有哪些编译配置。 正文 首先要知道什么时候会进行编译&#xff0c;有以下…