> 文章列表 > 初识MySql数据库

初识MySql数据库

初识MySql数据库

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

英文打字小游戏

                              MySql学习

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

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

初识MySql数据库

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

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

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

4:游戏服务器端

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

5:MySql的安装

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

6:MySql的启动

初识MySql数据库

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

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

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

9:MySql的控制台

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

初识MySql数据库
10:数据库的创建。数据库的名字是不区分大小写的。

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

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

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

初识MySql数据库

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

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

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就行。

数据库的恢复与备份:

初识MySql数据库

 

 

   

 

 

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

初识MySql数据库

 

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%’;

 

 
   

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

初识MySql数据库

 

 
   

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

初识MySql数据库

 

 

 

摄像头大全