MySQL是一个开放源代码的数据库管理系统(DBMS), 它是由MySQL AB公司开发、发布并支持的。MySQL是一个跨平台的开源关系型数据库管理系统,广泛地应用在Internet上的中小型网站开发中。今天往后咱们每天更新介绍数据库的基础知识,由浅及深的学习MySQL,希望大家能够对MySQL有更深的认识。
数据库由一批数据构成有序的集合,这些数据被存放在结构化的数据表里。数据表之间相互关联,反映了客观事物间的本质联系。数据库系统提供对数据的安全控制和完整性控制。下面将介绍数据库中的一些基本概念,包括:数据库的定义、数据表的定义和数据类型等。
实现数据共享,减少数据冗余
采用特定的数据类型
具有较高的数据独立性,具有统一的数据控制功能
在关系数据库中,数据库表是一系列二维数组的集合,用来存储数据和操作数据的逻辑结构。它由纵向的列和横向的行组成,行被称为记录,是组织数据的单位;列被称为字段,每一列表示记录的一个属性,都有相应的描述信息,如数据类型、数据宽度等。
例如一个有关作者信息的名为authors的表中,每个列包含所有作者的某个特定类型的信息,比如“姓名”,而每行则包含了某个特定作者的所有信息:编号、姓名、性别、专业。
数据类型决定了数据在计算机中的存储格式,代表不同的信息类型。常用的数据类型有:整数数据类型、浮点数数据类型、精确小数类型、二进制数据类型、日期/时间数据类型、字符串数据类型。
表中的每一个字段,就是某种指定数据类型,比如上图中“编号”字段为整数数据,“性别”字段为字符型数据。
主键(Primary Key)又称主码,用于唯一地标识表中的每一条记录。可以定义表中的一列或多列为主键,主键列上不能有两行相同的值,也不能为空值。假如,定义authors表,该表给每一个作者分配一个 “作者编号”,该编号作为数据表的主键,如果出现相同的值,将提示错误,系统不能确定查询的究竟是哪一条记录; 如果把作者的“姓名”作为主键,则不能出现重复的名字,这与现实中的情况不相符合,因此“姓名”字段不适合做为主键。
数据库系统由硬件部分和软件部分共同构成,硬件主要用于存储数据库中的数据,包括计算机、存储设备等。软件部分则主要包括DBMS、支持DBMS运行的操作系统,以及支持多种语言进行应用开发的访问技术等。
数据库系统有3个主要的组成部分。
数据库:用于存储数据的地方
数据库管理系统:用于管理数据库的软件
数据库应用程序:为了提高数据库系统的处理能力所使用的管理数据库的软件补充
数据库提供了一个存储空间用以存储各种数据,可以将数据库视为-一个存储数据的容器。一个数据库可能包含许多文件,一个数据库系统中通常包含许多数据库。
数据库管理系统(DataBase Management System, DBMS)是用户创建、管理和维护数据库时所使用的软件,位于用户与操作系统之间,对数据库进行统- -管理。 DBMS能定义数据存储结构,提供数据的操作机制,维护数据库的安全性、完整性和可靠性。
虽然已经有了DBMS, 但是在很多情况下,DBMS无法满足对数据管理的要求。数据库应用程序(DataBase Application)的使用可以满足对数据管理的更高要求,还可以使数据管理过程更加直观和友好。数据库应用程序负责与DBMS进行通信、访问和管理DBMS中存储的数据,允许用户插入、修改、删除DB中的数据。
对数据库进行查询和修改操作的语言叫做SQL。SQL的含义是结构化查询语言(StructuredQuery Language)。SQL 有许多不同的类型,有3个主要的标准: ANSI (美国国家标准机构)SQL,对ANSI SQL修改后在1992年采纳的标准,称为SQL -92或SQL2。最近的SQL-99标准,从SQL2扩充而来并增加了对象关系特征和许多其他新功能。其次,各大数据库厂商提供不同版本的SQL,这些版本的SQL不但能包括原始的ANSI标准,而且在很大程度上支持SQL-92标准。
SQL包含以下4个部分。
(1)数据定义语言(DDL): DROP、CREATE、ALTER等语句。
(2)数据操作语言(DML): INSERT (插入)、UPDATE (修改)、DELETE (删除)语句。
(3)数据查询语言(DQL): SELECT 语句。
(4)数据控制语言(DCL): GRANT、REVOKE、COMMIT、ROLLBACK等语句。
不同的程序设计语言会有各自不同的数据库访问接口,程序语言通过这些接口,执行SQL语句,进行数据库管理。主要的数据库访问接口有:
1. ODBC
Open Database Conectivity (ODBC,开放数据库互连)技术为访问不同的SQL数据库提供了一个共同的接口。ODBC使用SQL作为访问数据的标准。这一接口提供了最大限度的互操作性:一个应用程序可以通过共同的一组代码访问不同的SQL 数据库管理系统(DBMS)。
一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS,不直接与DBMS打交道,所有的数据库操作由对应的DBMS的ODBC驱动程序完成。也就是说,不论是Access、MySQL还是Oracle数据库,均可用ODBC API进行访问。由此可见,ODBC 的最大优点是能以统一的方式处理所有的数据库。
2. JDBC
Java Data Base Connectivity (JDBC, Java 数据库连接)用于Java应用程序连接数据库的标准方法,是- -种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问, 它由一组用Java语言编写的类和接口组成。
3. ADO.NET
ADO.NET是微软在.NET框架下开发设计的- -组用 于和数据源进行交互的面向对象类库。ADO.NET提供了对关系数据、XML和应用程序数据的访问,允许和不同类型的数据源以及数据库进行交互。
4. PDO
PDO (PHP Data Object)为PHP访问数据库定义了一个轻量级的、-致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函 数执行查询和获取数据。PDO是PHP5新加入的一个重大功能。
MySQL是一个小型关系数据库管理系统,与其他大型数据库管理系统(例如Oracle. DB2、SQL Server等)相比,MySQL 规模小、功能有限,但是它体积小、速度快、成本低,且它提供的功能对稍微复杂的应用来说已经够用,这些特性使得MySQL成为世界上最受欢迎的开放源代码数据库。
MySQL的主要优势如下:
(1)速度:运行速度快。
(2)价格:MySQL对多数个人来说是免费的。
(3)容易使用:与其他大型数据库的设置和管理相比,其复杂程度较低,易于学习。
(4)可移植性:能够工作在众多不同的系统平台上,例如: Windows、 Linux、 Unix、MacOS等。
(5)丰富的接口:提供了用于C、C++、Eiffel、 Java、 Perl、 PHP、Python、 Ruby和Tcl
等语言的API。
(6)支持查询语言: MySQL可以利用标准SQL语法和支持ODBC (开放式数据库连接)的应用程序。
(7)安全性和连接性:十分灵活和安全的权限和密码系统,允许基于主机的验证。连接到服务器时,所有的密码传输均采用加密形式,从而保证了密码安全。并且由于MySQL是网络化的,因此可以在因特网上的任何地方访问,提高数据共享的效率。
MySQL数据库管理系统提供了许多命令行工具,这些工具可以用来管理MySQL服务器、对数据库进行访问控制、管理MySQL用户以及数据库备份和恢复工具等。而且MySQL提供了图形化的管理工具,这使得对数据库的操作更加简单。
MySQL命令行实用程序
MySQL服务器端实用程序:
(1) mysqld: SQL后台程序(即MySQL服务器进程)。该程序必须运行之后,客户端才能通过连接服务器来访问数据库。
(2) mysqld_ safe: 服务器启动脚本。在UNIX和NetWare中推荐使用mysqld_ safe来启动mysqld服务器。mysqld_ safe 增加了一些安 全特性,例如当出现错误时重启服务器并向错误日志文件写入运行时间信息。
(3) mysql.server: 服务器启动脚本。在UNIX中的MySQL分发版包括mysql.server 脚本。该脚本用于使用包含为特定级别的、运行启动服务的脚本的、运行目录的系统。它调用mysqld_ safe 来启动MySQL服务器。
(4) mysql muli:服务器启动脚本,可以启动或停止系统上安装的多个服务器。
(5) myisamchk:用来描述、检查、优化和维护MyISAM表的实用工具。
(6) mysqlbug: MySQL 缺陷报告脚本。它可以用来向MySQL邮件系统发送缺陷报告。
(7) mysql. install _db:该脚本用默认权限创建MySQL授权表。通常只是在系统上首次安装MySQL时执行一次。MySQL客户端实用工具程序如下:
(1) myisampack:压缩MyISAM表以产生更小的只读表的-一个工具。
(2) mysql:交互式输入SQL语句或从文件以批处理模式执行它们的命令行工具。
(3) mysqlaccess: 检查访问主机名、用户名和数据库组合的权限的脚本。
(4) MySQLadmin:执行管理操作的客户程序,例如创建或删除数据库,重载授权表,将表刷新到硬盘上,以及重新打开日志文件。MySQLadmin 还可以用来检索版本、进程,以及服务器的状态信息。
(5) mysqlbinlog: 从二进制8志读取语句的工具。在二进制日志文件中包含执行过的语旬,可用来帮助系统从崩溃中恢复。
(6) mysqlcheck: 检查、修复、分析以及优化表的表维护客户程序。
(7) mysqldump:将MySQL数据库转储到-一个文件(例如SQL语句或tab分隔符文本文件)的客户程序。
(8) mysqlhotcopy: 当服务器在运行时,快速备份MyISAM或ISAM表的工具。
(9) mysql import:使用LOAD DATA INFILE将文本文件导入相关表的客户程序。
(10) mysqlshow:显示数据库、表、列以及索引相关信息的客户程序。
(11) perror:显示系统或MySQL错误代码含义的工具。
MySQL Workbench
MySQL Wrkbench是下一代可视化数据库设计软件,MySQL Workbench为数据库管理员和开发人员提供了一整套可视化数据库操作环境,主要功能有:
数据库设计和模型建立。
SQL开发(取代MySQL Query Browser) 。
数据库管理(取代MySQL Administrator)。
MySQL Workbench有两个版本:
(1) MySQL Workbench Community Edition (也叫MySQL Workbench OSS,社区版),MySQL Workbench OSs是在GPL证书下发布的开源社区版本。
(2) MySQL Workbench Standard Edition (也叫MySQL Workbench SE,商业版) , MySQL Workbench SE是按年收费的商业版本。
好了,今天的MySQL更新就到这里,讲解的是最基本的基础,也是想帮大家夯实一下基础,为了以后更加牢靠的实战运用。
喜欢小编请多多点赞评论分享,让更多的人看到,关注小编,后续小编会继续创作,为大家献上更加精彩的文章~~~