前几天学习了mysql数据库的一些基础知识,了解了后台数据库的一些基础的数据操作:增删改查,对于项目前后台的数据传递有了些概念,总结了一些MySQL的基础语法。
一、数据存储形式发展和数据库作用
根据时间先后:层次模型,网状模型,传统层次模型,和关系模型。
数据库作用:1.存储大量数据,访问和检索数据;2.保证数据的完整性;3.安全与共享;4.数据可以进行组合,产生新的数据
二、关系模型
关系模型是实体,和联系组成的关系网,所谓实体就是指现实世界中客观存在并可相互区别的实物。实体具有属性,属性用于描述实体。以关系模型创建的数据库称为关系型数据库(relational database)。表是关系型数据库的核心单元,他是数据存储的地方。
三、结构化查询语言SQL
SQL是一种用于管理关系型数据库,与数据库中的数据进行通讯的计算机标准语言
分为:1.数据定义语言(DDL)
2.数据查询语言(DQL)
3.数据操作语言(DML)
4.数据控制语言(DCL)
四、增加
创建数据库:
create database 数据库名
使用数据库
use 数据库名
删除数据库
DROP DATABASE 数据库名
创建表格
create table student(表名){ stuNum int primary key auto_increment,-- 数据类型,主键,自增 stuName varchar(20), --数据类型 sex char(2) default “男”, --数据类型,默认值 card char(18) unique not null, --数据类型,唯一,不为空 s_c_id int references t_class(c_id), --数据类型,外键 constraint foreign key(s_c_id) references t_class(c_id) --外键约束 }
添加表格列
alter table 表名 add 列名 列名数据类型 列约束
删除表格列
alter table 表名 drop column 列名
五、DML语句更改数据
添加数据
insert into 表名(字段) values(字段对应的值)
修改数据
update 表名 set 列=新值 where 条件
六、DQL语句查询数据‘
’查询
select * from 表名 where 条件
去重
select distinct 列名 from 表名 where 条件
模糊查询
select * from 表名 where name like ‘李%’ //0个或多个字符
select * from 表名 where name in(‘’啊’,方,’哈’’)
Select * from 表名 where email is null //查询是否为null
排序
Select 列名 from 表名 where 条件 order by 列名 ASC// asc 升序 desc 降序
分组
Select 列字段 from 表名 group by 列字段
七、子查询
select子查询:要求返回单行 和单列 相关
select * (select name1 from goods2 where name1=goods.name)as name1 from 表名
from 子查询:返回多行多列 表结构 非相关
Select * from (select * from goods limit 10)as t where 条件
where 子查询: 返回多行单列
Select * from student where ID in (select gid from ggg where name in (‘1’“2”))
八、表连接
1.Select * from 表1 join 表2 on 表1.ID=表2.ID 内连接:两个表都存在的数据 2.Select * from 表1,表2 where 表1.ID=表2.ID 内连接另一种写法 3.Select * from 表1 left outer join 表2 on 表1.ID=表2.ID 左外链接 4.Select * from 表1 right outer join 表2 on 表1.ID=表2.ID 右外链接 5.Select * from 表1 as 1 join 表1 as 2 on 条件 自连接