非关系型数据库、关系型数据库、MySQL服务器内部对象

非关系型数据库:Memcached、MongoDB、Redis

  效率高,不安全(断电丢失)

数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼(DBS = DBMS + DB)

关系型数据库:是一种建立在关系模型(数学模型)上的数据库

  大型{Oracle、DB2}、中型{SQL Server、MySQL}、小型{Access、SQLite等}

  安全(保存磁盘,基本不可能丢失),容易理解,比较浪费空间(二维表)

p:关系模型:包含数据结构、操作指令集合、完整性约束

数据库:存储数据的仓库、高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)

分类:基于存储介质的不同:分为关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL)

DBMS:Database Management System,数据库管理系统,专门管理数据库

DBA:Database Administrator,数据库管理员

SQL:(Structured Query Language)结构化查询语言

SQL分为三个部分:DDL数据定义语言、DML数据操作语言、DCL数据控制语言

DDL:用来维护存储数据的结构(数据库、表),代表指令:create、drop、alter等

DML:用来对数据进行操作(数据表中的内容),代表指令:insert、delete、update等。其中DML内部又单独进行了一个分类:DQL,如select

DCL:主要是负责权限管理(用户),代表指令:grant、revoke等

交互方式:*客户端连接认证:连接服务器、认证身份(mysql.exe -hPup)

*客户端发送SQL指令

*服务器接收SQL指令,并处理SQL指令,返回操作结果

*客户端接收结果,并显示结果

*断开连接

MySQL服务器内部对象:系统(DBMS)、数据库(DB)、数据表(Table)、字段(Field)

SQL基本操作:库操作、表操作(包含字段操作)、数据操作

库操作:create database 数据库名字 [库选项];

字符集设定:charset/character set 具体字符集(数据存储的编码格式,常用的有:GBK和UTF8)

校对集设定:collate 具体校对集(数据比较的规则)

数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)

每个数据库下都有一个opt文件,保存了库选项

查看所有数据库:show databases;

查看指定部分的数据库(模糊查询):show databases like 'pattern';

查看数据库的创建语句:show create database 数据库名字;

数据库名字不可以修改

数据库的修改仅限库选项,即字符集和校对集(校对集依赖字符集)

alter database 数据库名字 [库选项];

charset/character set [=] 字符集

collate 校对集

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

表操作:

*新增数据表

create table [if not exists] 表名(

字段名字 数据类型,

字段名字 数据类型

) [表选项];

*控制表的表现

字符集:charset/character set 具体字符集;     -- 保证表中数据存储的字符集

校对集:collate 具体校对集

存储引擎:engine 具体的存储引擎(innodb和myisam)

出错解决:1create table 数据库名.表名();   2进入数据库环境:use 数据库名字;

查看所有表:show tables;

查看部分表(模糊查询):show tables like 'pattern';

查看表的创建语句:show create table 表名;

查看表结构(表中的字段信息):desc/describe/show columns from 表名;

修改数据表:修改表名:rename table 旧表名 to 新表名;

修改表选项(字符集、校对集、存储引擎都可以修改):alter table 表名 表选项 [=] 值;

删除数据表:drop table 表名1,表名2……;

新增字段:alter table 表名 add [column] 字段名 数据类型 [列属性] [位置];

first:第一个位置

after:在哪个字段之后:after 字段名;

修改字段:alter table 表名 modify 字段名 数据类型 [列属性] [位置];

重命名字段:alter table 表名 change 旧字段 新字段名 数据类型 [列属性] [位置];

删除字段:alter table 表名 drop 字段名;

数据操作:     insert into 表名 values(值列表)[,(值列表)];

insert into 表名 (字段列表) values (值列表) [,(值列表)];

查看所有数据:select * from 表名 [where 条件];

查看指定字段、指定条件的数据:select 字段列表 from 表名 [where 条件];

update 表名 set 字段 = 值 [where 条件];

建议都有where,否则就是更新全部

删除是不可逆的,谨慎删除:delete from 表名 [where条件];

小注意点:  行/记录:row/record    列/字段:column/field

p:pattern是匹配模式:%表示匹配多个字符、_表示匹配单个字符

你可能感兴趣的:(非关系型数据库、关系型数据库、MySQL服务器内部对象)