使用MySql数据库的英文打字小游戏:
英文打字小游戏
MySql学习
1:MySql是关系型数据库,跨平台的。Sql Server是微软出的啊。
2:Web服务器端运行原理图。
Web服务器:网页资源的获取
游戏服务器:游戏数据的同步,账号的登录。
IP地址:电脑与电脑之间通信就会通过IP地址查找到对方电脑的位置。通过IP地址定位电脑的位置。每一个网址都会有一个IP地址,这个IP地址的解析是自动的,通过IP就能找到电脑。一台电脑是有多个软件的,当你通过IP找到电脑,请求数据时,不但需要你的IP地址还需要对应申请数据的软件的端口号,这个端口号是操作系统分配的未被使用的端口号。访问网站时没有输入端口号是因为有默认端口号的嘞。
4:游戏服务器端
图同上,原理同上,游戏服务器,而已。
5:MySql的安装
MySql默认有一个超级管理员,root 。
6:MySql的启动
7:如何在MySql中存储数据?MySql下可以创建多个库 (数据库) databases
一个库中可以创建多个表 (表格) tables (直接将库理解为Excel,表理解为sheet也没问题)
8:什么是表?MySql中需要先定好表头,表头表示我们的表有哪些列,表里面的每一行都是我们存储的数据。
9:MySql的控制台
MySql的可视化窗口安装路径可以打开,小图标也可以。
10:数据库的创建。数据库的名字是不区分大小写的。
11:在MySql Workbench图形化的界面中进行的每一步,都会发送一个Sql命令或Sql语句。Sql语句是一个结构化查询语句(Structed Query Language) Sql语句不同的数据库是相同的,增删改查的命令通常是一样的,只有一些微小的区别。
12:MySql的增删改查。表中有一行一行的数据嘛,我们怎么来区分两个账号是否是一样的嘞,就是通过主键来进行区分。每一行的主键都一定是不同的。
一个表必须有主键,一般创建一个表头id来作为主键的标识。并且只能有一个主键。主键不能为null(空值)。某一个字段定义为了自动增长那么他必须是主键。如果你给两个字段设置为主键那么,这两个主键的组合将作为一个新的主键,所以说只有一个主键。Unique的限制可以两条数据为null,但是不能在不为null是重复。
13:角色表的设计。一般情况下,数据库的表结构设计好之后就不允许更改了,所以说我们要将数据库的表结构设计得更加容易扩展。怎么设计角色的存储呢?在账号密码的表之外在创建一个表来存储角色信息。因为user与role表需要进行关联,这里就需要用到外键关联了:
关联发起者的列设置的值必须在被关联的列中存在,不然提交会不成功,这里的外键关联也相当于一种限制,被关联者的列一定是主键所在的列哦!外键是允许为空的。
你修改表结构,修改的数据必须符合修改后的表结构,不然会报错。
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就行。
数据库的恢复与备份:
可以用文本文档直接打开。数据导出的是一个一个的Sql语句。也阔以用这个来学习Sql语句。
导出之后可以在bench中将数据库删除了。然后根据数据库的备份来恢复数据库。
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%’;
这两个改成支持中文的编码模式,才能支持中文
首先将my.ini拷贝一份,然后向图片的下面这么做。完成后记得重启Sql server吧,打开任务管理器的方式:ctrl + shift + esc。