当前位置:Gxlcms > 数据库问题 > mysql轻快入门

mysql轻快入门

时间:2021-07-01 10:21:17 帮助过:25人阅读

.

账:就是数据/信息,

记账-->就是储存数据/信息

无论记在哪儿: 记录的都是信息, 变化的只是信息的载体. 

随着现代社会数据的急剧增多,我们用更高效的记录信息的方式.

 

一台服务器下有多个库,一个库下有1到多张表, 表有多行多列的数据.

作为开发程序员, 和表的操作相对多.


数据库服务器是不是mysql?

: 对于数据库存储数据来说,国际上有sql标准.

:列类型,sql语法等是有ISO标准的.

很多软件开发商,遵守sql标准,来开发一套软件,用来储存和管理数据.

这套软件,就可以称为数据库管理系统.

 

就好比说,看网页可以用 firefox,IE,chrome,

管理数据呢,可以用mysql, oracle,IBM DB2, sqlite, postgresql

这些软件都能够用来管理数据.

 

数据库大体上要遵循sql标准,但未必100%遵循.

:不是的,各厂商的产品可能对sql标准的执行有微小差异.

比如 mysql就没有全连接 full join, 没有sql server中的 top N这种用法

就好像,htmlw3c标准来约束,但各浏览器也有解析不兼容的地方,但是少数.

 

为什么要先用mysql来学习?

:

1:mysqllinux php,apache,配合紧密,LAMP架构.

2:mysql开源,免费.

 

请同学们有时间也可以关注一下postgresql

:postgresql也是一个开源数据库,而且sql标准执行方面,mysql要严格.

Mysql-->卖给->sun-->oracle, 版权开源方面前途未卜.

 

 

安装Mysql,装哪一个版本?

:对于软件,尤其是开源软件,不要追求最新的版本.

往往最新的版本,意味着bug,新用户往往成了"小白鼠"

 

开源软件的版本,一般会有beta,stable.

我们尽量选用稳定版.

 

目前,比较稳定的2个版本,mysql5.1, mysql5.5


连接数据库:以命令行连接为例:

注意:如果在命令提示下,出现如下提示:

 

 

 

 

则说明:没有配置环境变量,导致系统找不到mysql.exe.

解决:

1:配置环境变量,指定mysql\bin目录

2:每次进入到mysql\bin目录,再运行mysql

 

3: 如何连接服务器

   服务器地址( 可用IP,域名) : 端口(3306)

   用户名

   密码

Mysql -h localhost -uUserName -pPassWd

-h 如果不写,则默认连localhost

 

如果看到下面的图标

 

则说明连接服务器成功了.

 

 

澄清一个概念

连接成功后,:命令行黑窗口  和  mysql服务器是什么关系?

: 客户端 client --> 服务端 server的关系.

 

就好像 你的浏览器与--->163网站的服务器的关系一样.

 

还有没有其他mysql客户端?

:,navcat,mysqlfront,phpMyAdmin,SQLyogEnt
入门最基本语句

 

当连上服务器后,我们首先面对的是?

:是库,库有1个或多个,因此我们要想对表/行做操作的话,

得先选库.

 

查看一下所有的库,怎么办?

Mysql>Show databases;

 

选库语句: Use 库名

 

 

创建一个数据库: create database 数据库名 [charset 字符集]

 

 

删除一个数据库: drop database 数据库名;

 

 

把数据库改改名?

Mysql,/列可以改名,database不能改名.

phpMyAdmin似乎有这功能? 他是建新库,把所有表复制到新库,再删旧库完成的.

 

 

当选了库之后,我们面对的是表

查看库下面的所有表: show  tables;

 

先给大家提供一个简单的建表语句,供练习用

create table stu (

snum int,

sname varchar(10)

)engine myisam charset utf8;

/// engine是指表引擎,和性能特点相关,此处先照抄.

 

删除表: drop table stu;

 


修改表名:

 

 

清空表数据: truncate 表名

 

 

Truncatedelete是有区别的,

在于 truncate相当于删表再重建一张同样结构的表,操作后得到一张全新表.

delete是从删除所有的层面来操作的.

Trucate相当于把旧的学籍表扔了重画一张,

Delete相当于用橡皮把学籍表的数据库擦掉.

如果决定全清空的下,truncate速度更快一些.

 

 

查看表结构

: desc tableName; //查看表结构

Id

title

 

 

 

12: 解决字符集问题:

默认建表一般用utf8, 而我们在windows下窗口是GBK,

因此,需要声明字符集.

Set names gbk;

 

发现的1小问题

语句打错以后应该退出本语句,再继续打新语句.也可以打\c,退出本语句.

 

如何破解数据库的密码:

1:通过任务管理器或者服务管理,关掉mysqld(服务进程)

2:通过命令行+特殊参数开启mysqld

Mysqld --skip-grant-tables

3:此时,mysqld服务进程已经打开,并且,不需要权限检查.

4:mysql -uroot  无密码登陆服务器.

5: 修改权限表

  A: use mysql;

  B:update user set Password = password(‘11111‘) where User = ‘root‘;

  C:flush privileges;


6:通过任务管理器,或服务管理,关掉mysqld服务进程.

7:再次通过服务管理,打开mysql服务.

即可用修改后的新密码登陆.

 

 

增删改查基本语法学习

 

: insert

Insert 3:

1: 插入哪张表?

2: 插入哪几列?

3: 这几列分别插入什么值?

 

Insert into TableName

(1,2.... n)

Values

(1,2,....n)

 

,按顺序,一一对应

 

 

特殊: insert语句 允不允许不写列名

: 允许.

如果没有声明列明,则默认插入所有列.

因此,值应该与全部列,按顺序一一对应.

 

:建一张工资登记表

 

 

2:插入部分列

 

 

3:插入所有列

 

注:文中的set names gbk;是为了告诉服务器,客户端用的GBK编码,防止乱码.

 

4:插入所有的列的简单写法.

 


: Update 语句

Update 4

改哪张表?

改哪几列的值?

分别改为什么值?

在哪些行生效?

 

语法:

Update 表名

Set

1 = 新值 1,

2 = 新值2,

n = 新值n.....

Where  expr

:

 

 

 

删除: delete

Delete 2

从哪张表删除数据?

要删除哪些行?

 

语法:

Delete from 表名 where  expr

 

:

 

 

: select

查询3

1:查哪张表的数据?

2:查哪些列的数据?

3:查哪些行的数据?

 

语法:

Select 1, 2, 3,...n

From 表名

Where expr;

 

: 如果取一张表的所有列, 可以用 * 代替所有列

 


怎么建表?

以在A4纸上建表为例,

学号

姓名

家乡

入学年份

自我介绍

001

张三

衡水

2012

 

 

 

 

 

 

 

分析:我们只要把第一行,表头建好了,这张表也就完成了.

至于下面的001,张三,这不是表的概念,而是表中储存的数据.

 

其实,建表过程,就是一个画表头的过程,

从术语上讲,这张表有5个列,

建表的过程,就是一个 声明字段 过程

 

 

那么建表和列类型又有什么关系呢?

分析: 再看上面的表,A4纸是数据的存储空间,A4的大小是有限的.

请问:你准备给学号留多宽? 给姓名留多宽? 自我介绍又留多宽?

 

自然的, 姓名如果留的过宽,比如20个字都能存,但是一般人的姓名,就三四字---浪费了.

如果留的过窄,导致存不下,更有问题.

 

对应的,A4纸空间有限,硬盘空间也有限,

我们建列时,自然想的是------能够容纳放置的内容,但是又不浪费.

 

存储同样的数据,不同的列类型,所占据的空间和效率是不一样的--这就是我们建表前要前列类型的意义.

 

 

所以---重点学列类型的存储范围与占据的字节关系.

 

 

 

列类型学习

mysql三大列类型

数值型  

整型

   Tinyint/ smallint/ mediumint/int/ bigint(M) unsigned zerofill

 

整型系列所占字节与存储范围的关系.

定性: 占字节越多,存储范围越大.

下图: 是具体的数字分析

 

Tinyint 1个字节 8个位  0 - 2^8-1  ,  0-255

                -2^7 ----> +2^7-1

 

 

分析:

Smallint 2个字节 , 16位  0----2^16-1 = 65535

                -2^15 ---> +2^15-1, -32768 -> 32767

 

一般而言,设某类型 N字节

N字节 , 8N.

0 ----> 2^8N-1

 

-2^(8N-1)  ---> +2^(8N-1) -1;

 

对于int: 占的字节越多,存储的范围也越大.


整型系统的可选参数 : XXint(M)  unsigned zerofill

: age tinyint(4) unsigned ,或者  stunum smallint(6) zerofill;

Unsigned: 代表此列为无符号类型, 会影响到列的存储范围. (范围从0开始)

(不加unsinged, 则该列默认是有符号类型,范围从负数开始)

 

 

 

Zerofill: 代表0填充, : 如果该数字不足参数M, 则自动补0, 补够M.

1: 如果没有zerofill属性, 单独的参数M,没有任何意义.

2:如果设置某列为zerofill,则该列已经默认为 unsigned,无符号类型.

 

 

 


小数型

 

Float(M,D),decimal(M,D)

  M"精度" ---->代表"总位数",D"标度",代表小数位.(小数右边的位数)

 

 

浮点数占多大的空间呢

答: float 能存10^38 ,10^-38

如果M<=24, 4个字节,否则占8字节

 

用来表示数据中的小数,除了float---浮点.

还有一种叫定点decimal,定点是把整数部分, 和小数部分,分开存储的.

float精确,他的长度是变化的.

 

空间上的区别:

Float(M,D), M<=24, 4个字节, 24 <M <=53, 8个字节

Decimal () ,变长字节.

 

区别: decimalfloat精度更高, 适合存储货币等要求精确的数字,

见下例:

 


字符串型 

Char(M)

Varchar(M)

Text 文本类型

 

日期时间类型

Date 日期

Time 时间

Datetime 时间时间类型

Year 年类型

 

 

 

Mysql 字符串类型

Char 定长类型

Char(M)  , M 代表宽度, 0<=M<=255之间

:Char(10)  ,则能输入10个字符.

 

Varchar 变长类型

Varchar(M), M代表宽度, 0<=M<=65535(ascii字符为例,utf822000左右)

 

类型

类型

宽度

可存字符

实存字符(i<=M)

实占空间

利用率

Char

M

M

i

M

i/M <= 100%

Varchar

M

M

i

i字符+(1-2)字节

i/(i+1-2) < 100%

 

0000000000

00\0\0\0\0\0 (char,如果不够M个字符,内部用空格补齐,取出时再把右侧空格删掉)  

:这意味着,如果右侧本身有空格,将会丢失.

 

Varchar(10)

[2]张三

[3]二麻子

[4]司马相如

 

Char(8)

00000000

‘Hello   ‘

‘hello ‘

Char(M)如何占据M个字符宽度?

: 如果实际存储内容不足M,则后面加空格补齐.

取出来的时候, 再把后面的空格去掉.(所以,如果内容最后有空格,将会被清除).

 

 

速度上: 定长速度快些

 

注意: char(M),varchar(M)限制的是字符,不是字节.

char(2) charset utf8, 能存2utf8字符. 比如中国‘charvarchar型的选择原则:

1:空间利用效率, 四字成语表, char(4),

个人简介,微博140, varchar(140)

2:速度

用户名: char

 

 

Char varchar相关实验

 

 

 

Text : 文本类型,可以存比较大的文本段,搜索速度稍慢.

因此,如果不是特别大的内容,建议用char,varchar来代替.

Text 不用加默认值 (加了也没用).

 

Blob,是二进制类型,用来存储图像,音频等二进制信息.

意义: 2进制,0-255都有可能出现.

Blob在于防止因为字符集的问题,导致信息丢失.

比如:一张图片中有0xFF字节, 这个在ascii字符集认为非法,在入库的时候,被过滤了.

 


日期时间类型

Year (1字节)    95/1995,  [1901-2155],

insert,可以简写年的后2,但是不推荐这样.

[00-69] +2000

[70-99] + 1900,   

: 2,表示 1970 - 2069

 

Date 日期  1998-12-31

范围: 1000/01/01 ,9999/12/31

 

Time 时间  13:56:23

范围: -838:59:59 -->838:59:59


datetime 时期时间  1998-12-31 13:56:23

范围: 1000/01//01 00:00:00  ---> 9999:12:31 23:59:59

 

timestamp

 

时间戳:

1970-01-01 00:00:00 到当前的秒数.

一般存注册时间,商品发布时间等,并不是用datetime存储,而是用时间戳.

因为datetime虽然直观,但计算不便.

 

 


建表案例,某高端白领私密社交网站

 

定长与变长分离

常用与不常用列分离

 

主键

用户名

性别

体重(KG)

生日

工资

上次登陆

个人简介

id

Username

gender

weight

birth

salary

Lastlogin

intro

 

列名称

列类型

默认值

是否主键

Id

Int unsigned

 

PRI

Username

Varchar(20)

‘‘

 

gender

Char(1) /tinyint/enum(/)

 

 

weight

Tinyint unsigned

 

 

Birth

Date

 

 

Salary

Decimal(8,2)

 

 

lastlogin

Datetime

 

 

intro

Varchar(1500)

 

 

 

这张表不够好,可以优化

分析:这张表除了username/intro列之外,每一列都是定长的.

我们不妨让其所有列,都定长,可以极大提高查询速度.

列名称

列类型

默认值

是否主键

Id

Int unsigned

 

PRI

Username

char(20)

‘‘

 

gender

Char(1) /tinyint

 

 

weight

Tinyint unsigned

人气教程排行