什么是数据库
-
数据库:英文为 DataBase,简称DB,它是存储和管理数据的仓库。
-
数据是存储在数据库中的,那我们要如何来操作数据库以及数据库中所存放的数据呢?
这里会涉及到一个软件:数据库管理系统(DataBase Management System,简称DBMS)
-
DBMS是操作和管理数据库的大型软件。将来我们只需要操作这个软件,就可以通过这个软件来操纵和管理数据库了。
-
此时又出现一个问题:DBMS这个软件怎么知道要操作的是哪个数据库、哪个数据呢?是对数据做修改还是查询呢?
-
需要给DBMS软件发送一条指令,告诉这个软件我们要执行的是什么样的操作,要对哪个数据进行操作。而这个指令就是SQL语句
-
SQL(Structured Query Language,简称SQL):结构化查询语言,它是操作关系型数据库的编程语言,定义了一套操作关系型数据库的统一标准。我们学习数据库开发,最为重要的就是学习SQL语句 。
-
结论:程序员给数据库管理系统(DBMS)发送SQL语句,再由数据库管理系统操作数据库当中的数据。
主流的数据库
-
Oracle:大型的收费数据库,Oracle公司产品,价格昂贵。(通常是不差钱的公司会选择使用这个数据库)
-
MySQL:开源免费的中小型数据库,后来Sun公司收购了MySQL,而Oracle又收购了Sun公司。目前Oracle推出两个版本的Mysql:社区版(开源免费)、商业版(收费)。
-
SQL Server:Microsoft 公司推出的收费的中型数据库,C#、.net等语言常用。
-
PostgreSQL:开源免费的中小型数据库。
-
DB2:IBM公司的大型收费数据库产品。
-
SQLLite:嵌入式的微型数据库。Android内置的数据库采用的就是该数据库。
-
MariaDB:开源免费的中小型数据库。是MySQL数据库的另外一个分支、另外一个衍生产品,与MySQL数据库有很好的兼容性。
MySQL安装
安装
MySQL官方提供了两个版本:
-
商业版本(MySQL Enterprise Edition)
-
该版本是收费的,我们可以使用30天。 官方会提供对应的技术支持。
-
-
社区版本(MySQL Community Server)
-
该版本是免费的,但是MySQL不会提供任何的技术支持。
-
官网下载地址:MySQL :: Download MySQL Community Server (Archived Versions)
连接
MySQL服务器启动完毕后,然后再使用如下指令,来连接MySQL服务器:
mysql -u用户名 -p密码 [-h数据库服务器的IP地址 -P端口号]
-h 参数不加,默认连接的是本地 127.0.0.1 的MySQL服务器
-P 参数不加,默认连接的端口号是 3306
上述指令,可以有两种形式:
-
密码直接在-p参数之后直接指定 (这种方式不安全,密码直接以明文形式出现在命令行)
-
密码在-p回车之后,在命令行中输入密码,然后回车
通过MySQL的客户端命令行,可以来连接服务器上部署的MySQL :
关系型数据库(RDBMS)
概念:建立在关系模型基础上,由多张相互连接的二维表组成的数据库。
二维表的优点:
-
使用表存储数据,格式统一,便于维护
-
使用SQL语言操作,标准统一,使用方便,可用于复杂查询
前面的MySQL、Oracle、DB2、SQLServer这些都是属于关系型数据库,里面都是基于二维表存储数据的。
结论:基于二维表存储数据的数据库就成为关系型数据库,不是基于二维表存储数据的数据库,就是非关系型数据库(如Redis,就属于非关系型数据库)。
-
通过MySQL客户端连接数据库管理系统DBMS,然后通过DBMS操作数据库
-
使用MySQL客户端,向数据库管理系统发送一条SQL语句,由数据库管理系统根据SQL语句指令去操作数据库中的表结构及数据
-
一个数据库服务器中可以创建多个数据库,一个数据库中也可以包含多张表,而一张表中又可以包含多行记录。
在Mysql数据库服务器当中存储数据,你需要:
先去创建数据库(可以创建多个数据库,之间是相互独立的)
在数据库下再去创建数据表(一个数据库下可以创建多张表)
再将数据存放在数据表中(一张表可以存储多行数据)