mysql学习一

基础

数据库的命令:

  查看所有数据库: show databases;

   查看当前使用的数据库:select database();

  切换数据库:use 数据库名;

  创建数据库:create database 数据库名 charset=utf8;

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

数据表的命令:

  查看所有的表:show tables;

  创建表:create table 表名(id int auto_increment primary key not null,...)

  删除表:drop table 表名;

  修改表:alter table 表名 add | change | drop 列;

数据的命令:

  查询:select * from 表名;

  增加:insert into 表名 values(...);

  修改:update 表名 set 字段=值 ...

  删除:delete from 表名;

  逻辑删除:在表中增加一个列,比如增加一个列名为isDelete的列,类型为bool类型,将需要删除的记录的该字段值修改为1,而不是正真删除该记录。查询时,只要查询isDelete=0的记录就可以了。

基本查询:

select * from 表名;

select 列名1,列名2,... from 表名;

distinct 关键字 消除重复的行

select distinct 列名1,列名2,... from 表名;

条件查询:

select * from 表名 where 条件;

模糊查询:

like:

%:表示任意多个字符

_:表示任意一个字符

select * from 表名 where 列名 like  'xx%x';

范围查询:

in:表示在一个非连续的范围内

  查询id为1或3或4的记录

  select * from 表名 where id in(1,3,4);

between ... and ... :表示在一个连续的范围内

  查询id在1到4之间的记录

  select * from 表名 where id between 1 and 4;

空判断:

  注意:null与''(两个单引号之间什么都没有,表示一个空字符串)是不同的

  判断:is null

聚合:mysql中常用的5个聚合函数

  count(*):计算总行数,括号中写*或列名

    select count(*)  from 表名;

  max(列):表示求此列的最大值

    select  max(id) from 表名;

  min(列):表示求此列的最小值

    select min(id) from 表名;

  sum(列):表示求此列的和

    select sum(id) from 表名;

  avg(列):表示求此列的平均值

    select avg(id) from 表名;

分组:

  按照字段分组:表示此字段相同的数据会被放到一个组中,分组后,只能查询出相同的数据列,对于有差异的数据列无法出现在结果集中。可以对分组后的数据进行统计,做聚合运算

  select 列1,列2,聚合 ... from 表名 group by 列1,列2...

  分组后的数据筛选:

    select 列1,列2,聚合 ... from 表名

    group by 列1,列2,列3...

    having 列1,...聚合...

  注意:having和where的区别:

    where:是对from后面指定的表进行数据筛选,属于对原始数据进行筛选

    having:表示对group by(分组后)的结果集进行筛选

    原始集---where--->结果集---group--->结果集---having--->

排序:

  select * from 表名 order by 列1 asc | desc,列2 asc | desc,...

分页:

  select * from 表名 limit start,count

  表示从start开始,获取count条数据,start索引从0开始

  示例:

    已知:每页显示m条数据,当前显示第n页(n从1开始)

    求总页数:

      查询总条数p1

      使用p1除以m得到p2

      如果整除则p2为总页数

      如果不整除则p2+1为总页数

    求第n页的数据

    首先计算第n页数据的开始索引,计算方法如下:

    n  start

    1  0       第一页,从0开始

    2  m      第二页,从m开始

    3  (n-1)*m  第n页,从(n-1)*m开始  

    select * from 表名 limit (n-1)*m,m

基础总结:

  完整的select语句的写法:

  select distinct * from 表名

  where ...

  group by ... having ...

  order by ...

  limit start,count

  执行顺序:

    from 表名

    where ...

    group by ...

    select distinct *

    having ...

    order by ...

    limit start,count

高级:关系,视图,事务,索引

关系:

学生表:成绩表:科目表

id    id    id

name  score    title

      stuid(对应学生表的id)

      subid(对应科目表的id)

CREATE TABLE students(
id INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20)
);
ALTER TABLE students ADD sname VARCHAR(20);
CREATE TABLE subjects(
id INT PRIMARY KEY AUTO_INCREMENT,
title VARCHAR(20)
);

CREATE TABLE scores(
id INT PRIMARY KEY AUTO_INCREMENT,
stuid INT,
subid INT,
score DECIMAL(5,2),
FOREIGN KEY(stuid) REFERENCES students(id),
FOREIGN KEY(subid) REFERENCES subjects(id)
);

外键的级联操作:

  在删除students表的数据时,如果该id值在scores中已存在,则报错。可以使用上面提到的

  逻辑删除解决该问题;可以在创建表时指定级联操作,也可以在创建表后再修改外键的级联操作

alter table scores add constraint stu_sco foreign key(stuid) references students(id) on delete cascade;

  级联操作的类型:

    restrict:默认值,抛异常

    cascade:如果主表的记录删除,则从表中相关联的记录都将被删除

    set null:将外键设置为空

    no action:什么都不做

连接:

连接查询分类:

  表A inner join 表B:表A和表B匹配的行会出现在结果中

  表A left join 表B:表A和表B匹配的行会出现在结果中,外加表A中独有的数据,未对应的数据使  用null填充

  表A right join 表B:表A和表B匹配的行会出现在结果中,外加表B中独有的数据,未对应的数据  使用null填充

在查询或条件中推荐使用"表名.列名"的语法

如果多个表中列名不重复可以省略"表名."部分

如果表的名称太长,可以在表名后面使用'as 简写名'或'简写名',为表起个临时简写名称

总结:

  select distinct 列*

  from 表1 inner | left | right join 表2 on 表1与表2的关系

  where ...

  group by ... having ...

  order by ... asc | desc

  limit start,count

  

自关联:

视图:

事务:

  使用事务可以完成回滚的功能,保证业务逻辑的正确性。

  四大特性(ACID)

  原子性(Atomicity):事务中的全部操作在数据库中是不可分割的,要么全部完成,要么全不执行。

  一致性(Consistency):几个并行执行的事务,其执行结果必须与按某一顺序串行执行的结果相一致。

  隔离性(Isolation):事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务必须是透明的。

  持久性(durability):对于任意已提交的事务,系统必须保证该事务对数据库的改变不被丢失,即使数据库出现故障。

  要求:表的类型必须是innodb或bdb类型,才可以对此表使用事务

  示例:

    show create table students;

    alter table '表名' engine=innodb;

索引:

 

    

  

 

posted @ 2018-01-12 22:25  blackx  阅读(214)  评论(0编辑  收藏  举报