• mysql(01)


    目录

    1.mysql简介

    2.mysql安装

    3.三个环境(对于系统开发而言)

    4.mysql之数据类型、建表以及约束

    5.四大引擎的作用及区别


    1.mysql简介

    why

    数据在内存中容易丢失,  数据在文件中,不便于操作

    what

    使用完整的管理系统统一管理,易于查询

    where

    凡是需要持久化存储数据的地方

            DB
    ​            数据库(database):存储数据的“仓库”。它保存了一系列有组织的数据。
    ​        DBMS
    ​            数据库管理系统(Database Management System),数据库是通过DBMS创建和操作的容器
    ​        SQL
    ​            结构化查询语言(Structure Query Language):专门用来与数据库通信的语言

    2.mysql安装


    my.ini
    [mysql]
     设置mysql客户端默认字符集
    default-character-set=utf8 

    [mysqld]
    #设置3306端口
    port = 3306
    # 设置mysql的安装目录
    basedir=D:\\tools\\mysql-5.7.23-winx64
    # 设置mysql数据库的数据的存放目录
    datadir=D:\\tools\\mysql-5.7.23-winx64\\data
    # 允许最大连接数
    max_connections=200
    # 服务端使用的字符集默认为8比特编码的latin1字符集
    character-set-server=utf8
    # 创建新表时将使用的默认存储引擎
    default-storage-engine=INNODB
    ```

    安装MySQL(8.0的版本)


    1.解压MySQL
    2.修改my.ini文件
    3.mysqld install
    4.mysqld --initialize --console
    5.net start mysql
    6.mysql -P 3306 -u root -p
    7.ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
    8.Navicat链接测试

    如果MySQL已经安装过,那么执行mysqld remove
     

    安装MySQL(5.7的版本)


    1.解压MySQL
    2.修改my.ini文件
    3.mysqld install
    4.mysqld --initialize --console
    5.net start mysql
    6.mysql -P 3306 -u root -p
    7.SET PASSWORD = PASSWORD("123456"); 
    8.Navicat链接测试

    如果MySQL已经安装过,那么执行mysqld remove
     

    删除MySQL(这是5.5版本的卸载方式)


    停止MySQL
    1添加删除程序中卸载MySQL
    2到安装目录删除MySQL
    3删除:C:\Documents and Settings\All Users\Application Data\MySQL
        C:\ProgramData\MySQL
    4查看注册表:
    regedit
    HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services
    HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services
    HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services
    搜索mysql,找到一律干掉!

    mysql安装步骤详情请看我 博客环境搭建&自定义mvc框架

    3.三个环境(对于系统开发而言)

    线网,生产环境:系统开发完毕,客户使用的那个环境

    测试环境:公司内部模拟客户现场,搭建而成的环境

    开发环境:本地电脑

    mysql自带的表,不能删哦

     

    4.mysql之数据类型、建表以及约束

    1.数据类型介绍

    MySQL中定义数据字段的类型对你数据库的优化是非常重要的。
    MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。
    1)字符类型:char varchar text blob
    2)数值类型:int bigint float decimal
    int -> int
    bigint -> long
    float -> 成绩
    decimal -> 货币类型(精度,小数)

    3)日期类型:date time datetime timestamp

    date -> yyyy:MM:dd HH:mm:ss
    time -> HH:mm:ss
    datetime -> yyyy:MM:dd
    timestamp(时间戳) -> 长整数
     

    2、建表、删表语法

    语法:
    create table 表名(
    列名 列的类型【(长度) 约束】,
    列名 列的类型【(长度) 约束】,
    列名 列的类型【(长度) 约束】,
    ...
    列名 列的类型【(长度) 约束】
    )



    #案例:创建表Book
    CREATE TABLE book(
    id INT,#编号
    bName VARCHAR(20),#图书名
    price DOUBLE,#价格
    authorId INT,#作者编号
    publishDate DATETIME#出版日期
    ​​
    );



    案例:创建表author
    CREATE TABLE IF NOT EXISTS author(
    id INT,
    au_name VARCHAR(20),
    nation VARCHAR(10)
    )
    DESC author;

    语法
    alter table 表名 add|drop|modify|change column 列名 【列类型 约束】;

    ①修改列名
    ALTER TABLE book CHANGE COLUMN publishdate pubDate DATETIME;

    ②修改列的类型或约束
    ALTER TABLE book MODIFY COLUMN pubdate TIMESTAMP;

    ③添加新列
    ALTER TABLE author ADD COLUMN annual DOUBLE;

    ④删除列
    ALTER TABLE book_author DROP COLUMN annual;

    ⑤修改表名
    ALTER TABLE author RENAME TO book_author;

    六大约束:
    NOT NULL:非空,用于保证该字段的值不能为空
    比如姓名、学号等
    DEFAULT:默认,用于保证该字段有默认值
    比如性别
    PRIMARY KEY:主键,用于保证该字段的值具有唯一性,并且非空
    比如学号、员工编号等
    UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空
    比如座位号
    CHECK:检查约束【mysql中不支持】
    比如年龄、性别
    FOREIGN KEY:外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值
    在从表添加外键约束,用于引用主表中某列的值
    比如学生表的专业编号,员工表的部门编号,员工表的工种编号

    5.四大引擎的作用及区别


    存储引擎查看
    MySQL给开发者提供了查询存储引擎的功能,我这里使用的是MySQL5.1,可以使用:
    SHOW ENGINES

    InnoDB存储引擎

    InnoDB是事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定和外键,上图也看到了,InnoDB是默认的MySQL引擎。InnoDB主要特性有:

    1、InnoDB给MySQL提供了具有提交、回滚和崩溃恢复能力的事物安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句中提供一个类似Oracle的非锁定读。这些功能增加了多用户部署和性能。在SQL查询中,可以自由地将InnoDB类型的表和其他MySQL的表类型混合起来,甚至在同一个查询中也可以混合

    2、InnoDB是为处理巨大数据量的最大性能设计。它的CPU效率可能是任何其他基于磁盘的关系型数据库引擎锁不能匹敌的

    3、InnoDB存储引擎完全与MySQL服务器整合,InnoDB存储引擎为在主内存中缓存数据和索引而维持它自己的缓冲池。InnoDB将它的表和索引在一个逻辑表空间中,表空间可以包含数个文件(或原始磁盘文件)。这与MyISAM表不同,比如在MyISAM表中每个表被存放在分离的文件中。InnoDB表可以是任何尺寸,即使在文件尺寸被限制为2GB的操作系统上

    4、InnoDB支持外键完整性约束,存储表中的数据时,每张表的存储都按主键顺序存放,如果没有显示在表定义时指定主键,InnoDB会为每一行生成一个6字节的ROWID,并以此作为主键

    5、InnoDB被用在众多需要高性能的大型数据库站点上
     

    MyISAM存储引擎

    MyISAM基于ISAM存储引擎,并对其进行扩展。它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。MyISAM拥有较高的插入、查询速度,但不支持事物。MyISAM主要特性有:

    1、大文件(达到63位文件长度)在支持大文件的文件系统和操作系统上被支持

    2、当把删除和更新及插入操作混合使用的时候,动态尺寸的行产生更少碎片。这要通过合并相邻被删除的块,以及若下一个块被删除,就扩展到下一块自动完成

    3、每个MyISAM表最大索引数是64,这可以通过重新编译来改变。每个索引最大的列数是16

    4、最大的键长度是1000字节,这也可以通过编译来改变,对于键长度超过250字节的情况,一个超过1024字节的键将被用上

    5、BLOB和TEXT列可以被索引

    6、NULL被允许在索引的列中,这个值占每个键的0~1个字节

    7、所有数字键值以高字节优先被存储以允许一个更高的索引压缩

    8、每个MyISAM类型的表都有一个AUTO_INCREMENT的内部列,当INSERT和UPDATE操作的时候该列被更新,同时AUTO_INCREMENT列将被刷新。所以说,MyISAM类型表的AUTO_INCREMENT列更新比InnoDB类型的AUTO_INCREMENT更快

    9、可以把数据文件和索引文件放在不同目录

    10、每个字符列可以有不同的字符集

    11、有VARCHAR的表可以固定或动态记录长度

    12、VARCHAR和CHAR列可以多达64KB

    使用MyISAM引擎创建数据库,将产生3个文件。文件的名字以表名字开始,扩展名之处文件类型:frm文件存储表定义、数据文件的扩展名为.MYD(MYData)、索引文件的扩展名时.MYI(MYIndex)
     

    MEMORY存储引擎

    MEMORY存储引擎将表中的数据存储到内存中,未查询和引用其他表数据提供快速访问。MEMORY主要特性有:

    1、MEMORY表的每个表可以有多达32个索引,每个索引16列,以及500字节的最大键长度

    2、MEMORY存储引擎执行HASH和BTREE缩影

    3、可以在一个MEMORY表中有非唯一键值

    4、MEMORY表使用一个固定的记录长度格式

    5、MEMORY不支持BLOB或TEXT列

    6、MEMORY支持AUTO_INCREMENT列和对可包含NULL值的列的索引

    7、MEMORY表在所由客户端之间共享(就像其他任何非TEMPORARY表)

    8、MEMORY表内存被存储在内存中,内存是MEMORY表和服务器在查询处理时的空闲中,创建的内部表共享

    9、当不再需要MEMORY表的内容时,要释放被MEMORY表使用的内存,应该执行DELETE FROM或TRUNCATE TABLE,或者删除整个表(使用DROP TABLE)
     

  • 相关阅读:
    【MySQL】MySQL索引的定义、分类、Explain、索引失效和优化
    你所不知道的端口耗尽(二)
    怎样选择一套适合自己的跨境商城源码?
    Java类配置Spring
    临界区、临界资源、共享资源、临界调度原则
    动态规划——最长上升子序列模型
    深度学习 Day 17——利用卷神经网络实现猫狗识别
    18、Flink的SQL 支持的操作和语法
    [Unity3D]用C#在unity里面写一个简单的红绿灯
    盲人出行挑战与曙光:“盲人视觉辅助技术研发”助力无障碍生活
  • 原文地址:https://blog.csdn.net/m0_68211831/article/details/125551696