mysql

数据库 - 数据的仓库(集散地) - database - 实现数据持久化和数据管理
持久化 - 将数据从内存转移到能够长久保存数据的存储介质的过程

数据库的分类:关系型数据库(SQL)和非关系型数据库(NoSQL)

文件系统 / 层次数据库 / 网状数据库

关系型数据库

  • 1970s - E.F.Codd - IBM研究员 - System R
  • 理论基础:关系代数和集合论
  • 具体表象:用二维表来保存数据 - 学生表
    ~ 行:一条记录 - 一个学生的信息
    ~ 列:一个字段 - 学生的某个属性,例如:学号、姓名、出生日期
    ~ 主键列:能够唯一标识一条记录的列,例如:学生的学号
  • 编程语言:SQL - 结构化查询语言
    ~ DDL - 数据定义语言 - create / drop / alter
    ~ DML - 数据操作语言 - insert / delete / update / select
    ~ DCL - 数据控制语言 - grant(授予)/ revoke(收回)

LAMP = Linux + Apache + MySQL + PHP(以前的黄金组合,淘宝第一代)

PHP ---> Java
MySQL ---> Oracle
Linux ---> 小型机

去IOE运动
IBM的小型机
Oracle的数据库
EMC的存储设备

关系型数据库产品:

  • Oracle - 甲骨文
  • IBM DB2
  • Microsoft SQLServer
  • Sybase

  • MySQL
  • PostgreSQL
  • SQLite

连接MySQL的图形化客户端工具:

  • Navicat for MySQL - 病猫
  • SQLyog - 海豚
  • Toad for MySQL - 蛤蟆
    -- SQL语法
    -- DDL(数据定义语言)
    -- DML(数据操作语言)
    -- DCL(数据控制语言)
    -- 注意:SQL中大小写不敏感(大写和小写一样的)
    -- 每条SQL语句必须以分号结束

-- 1.DDL - 主要提供数据库和表的创建,删除和修改
-- 0.DROP DATABASE 数据库名

DROP DATABASE school;  -- 直接删除指定的数据库
DROP DATABASE if EXISTS school;  -- 如果指定的数据库存在就删除数据库

-- 1.创建数据库: CREATE DATABASE 数据库名;

CREATE DATABASE school; -- 直接创建指定数据库
CREATE DATABASE if not EXISTS school;-- 当指定数据库不存在的时候才创建数据库
CREATE DATABASE if not EXISTS school DEFAULT CHARSET utf8; -- 创建数据库的时候设置字符集编码方式为utf8,让数据库支持中文数据存储

-- 2.使用/切换数据库: use 数据库名;

use school;

-- 3.新建表: CREATE TABLE if not EXISTS 表名(字段名1 类型1,字段2 类型2,...);
-- 注意: a.表名一般需要加前缀't'或者'tb' b.字段用来确定表中要存储哪些数据,字段名随便命名但是不能是关键字 c.数据类型必须是MYSQL支持的数据类型
-- 常用数据类型:int,char(size),varchar(size)-不定长字符串,text-字符串,bit-布尔

CREATE TABLE if not EXISTS t_student(
stuid int, stuname varchar(20), gender bit,birth date);

-- CREATE TABLE if not EXISTS 表名(字段名1 类型1 约束1,字段2 类型2 约束2,...);
-- 常用的约束: not null - 不能为空, DEFAULT - 设置默认值,unique - 值唯一,primary key - 主键约束 auto_increment 自动增长(只针对主键有效,不然会报错,并且主键的类型是整型)
-- 主键约束:主键指的是表中能够唯一标识一条记录的字段(通过主键值能够找到表中唯一一行记录)
-- 注意:一个字段可以添加多个约束,多个约束之间用空格隔开

CREATE TABLE if not EXISTS t_student(
stuid int not null auto_increment, 
stuname varchar(20) not null, 
gender bit DEFAULT 1,
birth date,
PRIMARY key(stuid));  -- 设置stuid为当前表的主键,(
设置一个字段为主键,其实间接的约束了这个字段是唯一的)

-- 4.删除表: DROP TABLE if EXISTS 表名;

DROP TABLE if EXISTS t_student;

-- 5.清空表中的记录: TRUNCATE TABLE 表名;
(慎用)

TRUNCATE TABLE t_student;

-- 6.修改表: FLOAT(5,2) 浮点型 长度为5 2是小数
-- a.添加字段:alter tabel 表名 add column 字段名 字段类型 约束;

ALTER TABLE t_student add COLUMN score FLOAT(5,
2) DEFAULT 0;

-- b.删除字段:alter table 表格 drop column 字段名;

ALTER TABLE t_student drop COLUMN gender;

--c. 改变初始列的字段的大小(如varchar(20)-->varchar(511))

alter table t_student change column gender  gender varchar(511);

-- 二, DML(数据操作语言) - 主要针对数据库中数据的增,删,改,查
-- 1.增(添加数据/记录)
-- 1.1插入数据/记录: insert into 表名 values(值1,值2,值3,...) - 依次给指定表中的字段赋值

INSERT into t_student VALUES(100,'张三',0, '2019-2-25');

-- 1.2插入数据/记录: insert into 表名(字段1,字段2,...) values(值1,值2,...) - 以指定的顺序给指定的字段赋值

insert into t_student(stuname, birth) values('小明','1991-10-20');-- 一次插入一条记录

-- 一次插入多条记录

insert into t_student (stuname, stusex) values 
('杨逍', default),
('赵敏', default),
('杨不悔', default),
('小昭', default);

-- 值的问题:SQL中是数字对应的直接写,字符串需要使用引号引起来,bit类型的值只有0或者1,时间可以是内容满足时间格式字符串也可以是通过时间函数获取的值
-- 时间函数:now() - 当前时间 date(now()) - 当前日期 year(now()) - 当前年 month(now()) -当前月

SELECT year(now());

-- 2.删(删除数据/记录)
-- delete from 表名; - 删除指定表中所有记录

DELETE FROM t_student;

-- delete from 表名 where 条件语句; - 删除满足条件的记录
-- SQL中的条件语句: =(判断是否相等), <>(不等于,和python中的!=功能一样),>,<,>=,<=

DELETE FROM t_student WHERE stuid=100; 
-- 删除表格中stuid的值等于100的记录
DELETE FROM t_student WHERE stuname='小花'; 
-- 删除表格中stuname的值等于小花的记录

-- 3.改(修改数据/记录)
-- update 表名 set 字段=新值; - 将指定表中所有行的指定列/字段的值赋值为新值

UPDATE t_student set birth='1999-10-1', gender=1;

-- update 表名 set 字段1=新值1,字段2=新值2,... where 条件语句; -将表中满足条件的行中指定字段的值赋值为新值

UPDATE t_student set gender=0 WHERE stuname='小花';

-- 通配符%: 表示任意个数的任意字符(包括0个)
UPDATE t_student set birth='2000-01-01' WHERE stuname LIKE '小%'; -- 修改stuname是以'小'开头对应的birth为'2000-01-01'

-- 通配符_:表示一个任意字符
UPDATE t_student set birth='2444-01-01' WHERE stuname LIKE '小_';-- 修改stuname只有两个字符,并且第一个字符是'小'
-- 注意:通配符只针对字符串有效

-- 4.查(获取数据)
-- 4.1直接查询
-- select * form 表名; - 获取指定表中所有行和所有的列(所有数据)

select * from t_student;

-- select 字段名1,字段名2,... from 表名; - 获取指定表中所有行指定的列

select stuname,stuid FROM t_student;

-- select * from 表名 where 条件; - 获取指定表中所有满足条件的行所有列的数据

select * FROM t_student WHERE stuid>115;

-- 4.2列重命名
-- select 字段1 as 新字段1, 字段2 as 新字段2,... from 表名;
-- 注意: 这儿的as可以省略,最好不要省

SELECT stuid as '学号', stuname, gender as '性别' FROM t_student; -- 对查询结果中的syuid和gender字段进行重命名

-- 4.3对查询结果重新赋值(一般针对布尔数据,这样有意义点)
-- select if(字段相关的条件语句,值1,值2) from 表名; - 查询指定字段对应的值是0还是1,如果是1结果为值1,否则为值2
-- 注意:这儿的if的用法是MYSQL专有的

-- MYSQL写法:if(字段, 新值1,新值2)
SELECT stuname,if(gender, '男', '女') as '性别' FROM 
t_student; -- 将1改为男, 0改为女, 字段改为性别
(原来是if(gender, '男', '女'))
-- 通用写法: case 字段 when 值 then 新值1 esle 
新值2 end
SELECT case gender WHEN 1 THEN '男' ELSE '女' END as 
'性别' FROM t_student;

-- 4.4对列进行合并
-- select concat(字段1,字段2,...) from 表名;

SELECT CONCAT(stuname,stuid) as 'name_id' from t_student;

-- 注意:数字和字符串数据可以合并,bit类型的数据不可以合并

-- select concat(stuname,':',gender) as 'name_id' 
from t_student;

-- 4.5模糊查询 - 查询的时候通过like条件来字典查询对象
-- sql中支持逻辑运算符and(逻辑与运算)和or(逻辑或运算),not(逻辑非)

select * from t_student where stuname like '%飞%' and 
stuid < 110; --查询名字有飞的同时id小于110的

-- 4.6排序(先按之前的任何语法进行查询在排序)
-- select * from 表名 order by 字段; - 对查询结果按照指定字段的值进行升序排序(也可以在字段后面加asc效果一样的)

-- select * from 表名 order by 字段 desc; 
- 对查询结果按照指定字段的值进行降序排序

-- 排序的时候可以通过在order by的后边加多个字段,进行联排。排序的时候前面的字段的优先级高些

select * from t_student order by gender ASC,stuid 
DESC; -- 先性别进行升序排序,然后再按学号降序排序。
写在前面的优先级高

-- 4.7限制
-- select * from 表名 limit N; -- 获取查询结果的前N条记录

SELECT * FROM t_student LIMIT 3; -- =获取查询结果的前3条
-- select * from 表名 limit M offset N; -- 对查询结果
跳过前N条数据,取M条数据数据出来
SELECT * FROM t_student LIMIT 3 OFFSET 4; 
-- 跳过前4条数据,然后取3条数据

你可能感兴趣的:(mysql)