mysql基础知识

mysql基础知识

数据库

典型的关系型数据库(存在表结构):

oracle:oracle公司的数据库产品

mysql :最早属于瑞典的MysqlAB公司->Sun公司,->Oracle

SQLserver:微软旗下的数据库产品

Access:微软旗下的数据库产品

DB2:IBM旗下的数据库产品

非关系型数据库:
HBase:是一个分布式、面向列的开源数据库

MongoDB是一个基于分布式文件存储的数据库

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、key-Value数据库、并提供多种语言的API.

TCL:事务

SQL:结构化查询语言 美国标,准(ANSI)

DDL(*)():数据定义语言,用来定义数据库对象:库、表、列等;

DML(**)():数据操作语言,用来定义数据库记录(数据);

DCL():数据控制语言,用来定义访问权限和安全级别;

DQL(*****)():数据查询语言,用来查询记录(数据)。

注意:语句;以结尾

数据库数据类型:

int double:double(5,2)表示最多有5位,其中必须有2位小数

字符串类型:char varchar Text(长文本)

blob:字节类型(例如图片)存储图片音频时,存的是主机,把目录存起来

date:格式为:yyy-MM-dd;

time:时间类型,格式为:hh-mm-ss

timestamp:时间戳类型yyyy-MM-dd hh:mm:ss 会自动赋值

datatime:日期时间类型 yyyy-MM-dd hh:mm:ss

字符串日期都是‘’ 空值null

当前数据库中的所有表

SHOW TABLES;

查看表的字段信息

DESC employee;

在上面员工表的基本上增加一个image列。

ALTER TABLE employee ADD image blob;

修改job列,使其长度为60。

ALTER TABLE employee MODIFY job varchar(60);

删除image列,一次只能删一列。

ALTER TABLE employee DROP image;

表名改为user。

RENAME TABLE employee TO user;

查看表格的创建细节

SHOW CREATE TABLE user;

修改表的字符集为gbk

ALTER TABLE user CHARACTER SET gbk;

列名name修改为username

ALTER TABLE user CHANGE name username varchar(100);

备份表结构和表数据

create table tname2 as select * from tname1;

备份表结构

create table tname2 like tname1;

删除表

DROP TABLE user ;

查询语句

DQL数据查询语言 (重要)

数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

查询返回的结果集是一张虚拟表。

查询关键字:SELECT

语法: SELECT 列名 FROM表名

【WHERE --> GOUP BY -->HAVING–> ORDER BY LIMIT】

语法:

SELECT selection_list /要查询的列名称/

FROM table_list /要查询的表名称/

WHERE condition /行条件/

GROUP BY grouping_columns /对结果分组/

HAVING condition /分组后的行条件/

ORDER BY sorting_columns /对结果排序/

LIMIT offset_start, row_count /结果限定/

条件查询:

就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

=、!=、<>、<、<=、>、>=;

BETWEEN…AND;

IN(set);

IS NULL;

AND;

OR;

NOT;

模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。

通配符:

_ 任意一个字母

​ %:任意0~n个字母

‘张%’

字段控制查询
去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:

查看和运算

因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,那么会出错。

给列名添加别名

在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total:

给列起别名时,是可以省略AS关键字的:

排序

查询所有学生记录,按年龄升序排序

SELECT

FROM stu

ORDER BY sage ASC;

或者

SELECT

FROM stu

ORDER BY sage;

聚合函数 sum avg max min count
分组查询

当需要分组查询时需要使用GROUP BY

HAVING子句

having与where的区别

having是在分组后对数据进行过滤

where是在分组前对数据进行过滤

having后面可以使用分组函数(统计函数)

where后面不可以使用分组函数。

WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。

8 LIMIT

LIMIT用来限定查询结果的起始行,以及总行数。

分页查询

查询语句书写顺序:select – from- where- group by- having- order by-limit

查询语句执行顺序:from - where -group by - having - select - order by-limit

数据完整性
实体完整性:(entity)
主键约束:

primary key(classid,stuid)

ALTER TABLE student ADD PRIMARY KEY (id);

注:每个表中要有一个主键。

特点:数据唯一,且不能为null

唯一约束:

unique 不认为null是重复

自动增长列

auto_increment

域完整性

域完整性 数据类型(数值类型、日期类型、字符串类型) 非空约束(not null) 默认值(default)
check约束 (mysql不支持) check(sex='男’or sex=‘女’)没有效果

引用完整性

外键 foreign key (uid) references 表名(uid)

删除主外键

alter table order1 drop Forelgn key 外键名字

第二种添加外键方式。

ALTER TABLE score1 ADD CONSTRAINT fk_stu_score FOREIGN KEY(sid) REFERENCES stu(id);

表与表之间的关系

一对一:例如t_person表和t_card表,即人和身份证。这种情况需要找出主从关系,即谁是主表,谁是从表。人可以没有身份证,但身份证必须要有人才行,所以人是主表,而身份证是从表。设计从表可以有两种方案:

在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;

给t_card表的主键添加外键约束(相对t_user表),即t_card表的主键也是外键。

一对多(多对一):最为常见的就是一对多!一对多和多对一,这是从哪个角度去看得出来的。t_user和t_section的关系,从t_user来看就是一对多,而从t_section的角度来看就是多对一!这种情况都是在多方创建外键!

多对多:例如t_stu和t_teacher表,即一个学生可以有多个老师,而一个老师也可以有多个学生。这种情况通常需要创建中间表来处理多对多关系。例如再创建一张表t_stu_tea表,给出两个外键,一个相对t_stu表的外键,另一个相对t_teacher表的外键。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值