美文网首页
2019-07-08

2019-07-08

作者: CC__XX | 来源:发表于2019-07-09 08:40 被阅读0次

    数据库

    MySQL数据库的基本操作(增删改查)
    高级操作
    视图
    备份和还原
    事务
    触发器
    函数
    存储过程

    什么是数据库?
    数据库(Database):存储数据的仓库
    高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)
    数据库的分类
    基于存储介质的不同:分为关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL)

    不同数据库阵营的产品
    关系型数据库
    大型:Oracle、DB2
    中型:SQL Server(微软)、MySQL
    小型:Access等适用于手机配置
    非关系型数据库:Memcached、MongoDB、Redis(可以同步到磁盘中)
    两种数据库阵营的区别
    关系型数据库:安全(保存磁盘,基本不可能丢失),容易理解,比较浪费空间(二维表)
    非关系型数据库:效率高,不安全(断电丢失)

    什么是关系型数据库?
    是一种建立在关系模型(数学模型)上的数据库
    关系模型:一种所谓建立在关系上的模型
    关系模型包含三个方面:
    数据结构:用于解决数据存储的问题,二维表(有行和列)
    操作指令集合:所有SQL语句
    完整性约束:表内数据约束(字段与字段)、表与表之间约束(外键)

    从需要存储的数据需求中分析,如果是一类数据(实体)应该设计成一张二维表:表是由表头和数据部分组成
    表头:即字段名,用来规定数据的名字
    数据部分:实际存储的数据单元
    关系型数据库,需要维护实体内部、实体与实体之间的联系
    如果表中对应的某个字段没有值(数据),但是系统依然要分配空间,所以说关系型数据库比较浪费空间

    数据库:database
    数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼
    DBS = DBMS + DB
    DBMS:Database Management System,数据库管理系统,专门管理数据库
    DBA:Database Administrator,数据库管理员
    行/记录:row/record
    列/字段:column/field

    SQL:(Structured Query Language,结构化查询语言)
    SQL分为三个部分:
    DDL:(Data Definition Language,数据定义语言)用来维护存储数据的结构(数据库、表),代表指令:create、drop、alter等
    DML:(Data Manipulation Language,数据操作语言)用来对数据进行操作(数据表中的内容),代表指令:insert、delete、update等。其中DML内部又单独进行了一个分类:DQL(Data Query Language,数据查询语言)如select
    DCL:(Data Control Language,数据控制语言)主要是负责权限管理(用户),代表指令:grant、revoke等

    1、客户端连接认证:连接服务器、认证身份(mysql.exe -hPup)
    2、客户端发送SQL指令
    3、服务器接收SQL指令,并处理SQL指令,返回操作结果
    4、客户端接收结果,并显示结果
    5、断开连接

    MySQL服务器内部对象分成了四层

    系统(DBMS)
    数据库(DB)
    数据表(Table)
    字段(Field)

    将SQL的基本操作根据操作对象进行分类,可分为三类:

    库操作
    表操作(包含字段操作)
    数据操作

    新增数据库

    create database 数据库名字 [库选项];
    库选项:用来约束数据库,分为两个选项
    字符集设定:charset/character set 具体字符集(数据存储的编码格式,常用的有:GBK和UTF8)
    校对集设定:collate 具体校对集(数据比较的规则)
    数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)

    创建结果:

    在数据库系统中,增加了对应的数据库信息
    会在保存数据的文件夹下(Data目录),创建一个对应数据库名字的文件夹
    每个数据库下都有一个opt文件,保存了库选项

    查看数据库

    查看所有数据库:show databases;
    查看指定部分的数据库(模糊查询):show databases like 'pattern';
    pattern是匹配模式
    %表示匹配多个字符
    _表示匹配单个字符
    查看数据库的创建语句:show create database 数据库名字;

    -- (单行注释)也可以使用#
    --创建数据库
    create database mydatabase charset utf8:
    
    create database `database` charset utf8:
    --创建中文数据库
    create database 中国 charset utf8;
    
    --中文字符集
    set names gbk;
    
    --查看所有的数据库
    show database;
    
    --创建数据库
    create database informationtest charset utf8;
    
    --查看以informationtest_开始的数据库(-下划线需要转义)
    --show databases like in "informationtest_%";
    
    show databases like in "informationtest/_%"
    --查看数据库的创建语句
    show create database mydatabase;
    show create database `database`;
    
    

    相关文章

      网友评论

          本文标题:2019-07-08

          本文链接:https://www.haomeiwen.com/subject/qivzhctx.html