MySQL数据库——数据库基础

二、数据库基础

1.主流数据库

  • SQL Sever:微软的产品,.Net程序员的最爱,中大型项目。
  • Oracle:甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。
  • MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。
  • PostgreSQL:加州大学伯克利分校计算机系开发的关系型数据库,不管是私用,商用,还是学术研究使用,可以免费使用,修改和分发。
  • SQLite::是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。
  • H2:是一个用va开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。
  1. mysql他是数据库服务的客户端
  2. mysqld是数据库服务的服务器端
  3. mysql本质:基于C(mysql)S(mysql)模式的一种网络服务

2.基本使用

①连接服务器

输入:

-h:连接地址,如果没有写默认是连接本地-h 127.0.0.1

-P:连接端口号,如果没有写默认是连接端口号3306

-u:连接到MySql服务器时使用的用户名

-p:表示需要输入密码

输出:

quit;-----> 退出

②服务器管理

执行win+r输入services.msc打开服务管理器

左侧选项可以停止、暂停、重启动进行服务管理

(在我的本机上安装了两个不同版本的MySQL)

③使用数据库

sql 复制代码
//创建数据库
mysql> create database helloworld;
Query OK, 1 row affected (0.00 sec)

//展示数据库
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| bookstore          |
| helloworld         |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
6 rows in set (0.00 sec)

//使用数据库
mysql> use helloworld;
Database changed

//创建表
mysql> create table student(
    -> name varchar(32),
    -> age int,
    -> gender varchar(2)
    -> );
Query OK, 0 rows affected (0.01 sec)

//向表中插入数据
mysql> insert into student (name, age, gender) values ('张三',20,'男');
Query OK, 1 row affected (0.00 sec)

//查询表中所有数据
mysql> select * from student;
+--------+------+--------+
| name   | age  | gender |
+--------+------+--------+
| 张三   |   20 | 男     |
+--------+------+--------+
1 row in set (0.00 sec)

mysql> 
  1. 建立数据库,本质就是在Linux下的一个目录(cd /var/lib/mysql
  2. 在数据库内建立表,本质就是在Linux下创建对应的文件即可
  3. 数据库本质其实也是文件,只不过这些文件并不由程序员直接操作,而是由数据库服务帮我们进行操作

④服务器/数据库/表的关系

  • 所谓安装数据库服务器 ,只是在机器上安装了一个数据库管理系统程序 ,这个管理程序可以管理多个数据库 ,一般开发人员会针对每一个应用创建一个数据库
  • 为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。
  • 数据库服务器、数据库和表的关系如下:

⑤MySQL架构

MySQL是一个可移植的数据库,几乎能在当前所有的操系统上运行,如Unix/LinuxWindowsMacSolaris。各种系统在底层实现方面各有不同,但是MySQL基本上能保证在各个平台上的物理体系结构的一致性。

⑥SQL分类

  • DDL【data definition1 anguage】数据定义语言 ,用来维护存储数据的结构
    • 代表指令:create,drop,alter
  • DML【data manipulation1 anguage】数据操纵语言 ,用来对数据进行操作
    • 代表指令:insert,delete,update
    • DML中又单独分了一个DQL数据查询语言
    • 代表指令:select
  • DCL【Data Contro1 Language】数据控制语言,主要负责权限管理和事务
    • 代表指令:grant,revoke,commit

⑦存储引擎

存储引擎是:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法

MySQL的核心就是插件式存储引擎,支持多种存储引擎

查看存储引擎的方法:show engines;

sql 复制代码
mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                        | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES        |
| MRG_MYISAM         | YES     | Collection of identical MyISAM tables                          | NO           | NO   | NO         |
| MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables      | NO           | NO   | NO         |
| BLACKHOLE          | YES     | /dev/null storage engine (anything you write to it disappears) | NO           | NO   | NO         |
| MyISAM             | YES     | MyISAM storage engine                                          | NO           | NO   | NO         |
| CSV                | YES     | CSV storage engine                                             | NO           | NO   | NO         |
| ARCHIVE            | YES     | Archive storage engine                                         | NO           | NO   | NO         |
| PERFORMANCE_SCHEMA | YES     | Performance Schema                                             | NO           | NO   | NO         |
| FEDERATED          | NO      | Federated MySQL storage engine                                 | NULL         | NULL | NULL       |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.00 sec)

mysql> 

各种存储引擎对比:

相关推荐
楠神说软件测试21 分钟前
MySQL调优
数据库·mysql
Cedric_Anik40 分钟前
MYSQL数据库基础篇——DDL
数据库·mysql
文牧之40 分钟前
PostgreSQL的walsender和walreceiver进程介绍
运维·数据库·postgresql
爬山算法43 分钟前
Oracle(121)如何进行数据文件的恢复?
数据库·oracle
咔咔学姐kk1 小时前
2024最新版,人大赵鑫老师《大语言模型》新书pdf分享
数据库·人工智能·语言模型·自然语言处理·pdf·知识图谱·产品经理
青云交1 小时前
大数据新视界 --大数据大厂之MongoDB与大数据:灵活文档数据库的应用场景
大数据·数据库·mongodb·非关系型数据库·文档存储·查询功能、数据处理·开发效率、应用场景、高可扩展性
青云交1 小时前
大数据新视界 --大数据大厂之HBase深度探寻:大规模数据存储与查询的卓越方案
大数据·数据库·hbase·数据存储·性能优势、问题解决、应用领域·可扩展性、高可靠性·读写性能、集群管理
茜茜西西CeCe1 小时前
大数据处理技术:HBase的安装与基本操作
java·大数据·数据库·hbase·头歌·大数据处理技术
shangan_32 小时前
黑马十天精通MySQL知识点
数据库·mysql
Jasonakeke2 小时前
【重学 MySQL】三十一、字符串函数
数据库·mysql