主要内容:
- 能够理解数据库的基本概念
- 能够安装,卸载及配置MySQL数据库
- 能够启动,关闭及登录MySQL数据库
1 数据库的基本概念
1.1 数据的存储方式
- 内存存储: Java中创建对象
Student s = new Student(1, "张三")
存在内存中; - 文件存储: Java IO流把数据保存到文件中;
- 数据库(DB, DataBase): 用于存储和管理数据的仓库。
|
|
|
---|---|---|
内存 | 速度快 | 不能永久保存,数据是临时状态 |
文件 | 数据可以永久保存 | 操作数据不方便,查询某个数据 |
数据库 | 1. 数据可以永久保存 2. 查询速度快 3. 对数据的管理方便 | 占用资源,需要购买 |
1.2 数据库的特点
- 持久化存储数据——数据库本质上是一个文件系统,还是以文件的方式存在服务器的电脑上的。
- 方便存储和管理数据
- 使用通用的结构化查询语言(SQL, Structured Query Language) 语句进行管理数据库
1.3 常见的数据库软件
数据库管理系统(DataBase Management System, DBMS): 指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据。
- MySQL: 开源免费的数据库,小型的数据库,已经被Oracle收购了。MySQL6.x版本也开始收费。后来Sun公司收购了MySQL,而Sun公司又被Oracle收购;
- Oracle: 收费的大型数据库,Oracle公司的产品;
- DB2: IBM公司的数据库产品,收费的。常应用在银行系统中;
- SQL Server: MicroSoft 公司收费的中型的数据库。C#、.net等语言常使用;
- SQLite: 嵌入式的小型数据库,应用在手机端,如:Android。
2 MySQL数据库软件
2.1 下载
官方下载地址:https://downloads.mysql.com/archives/community/
2.2 安装
2.2.1 Windows下安装
- 打开下载的MySQL安装文件双击解压缩,运行
mysql-5.5.40-win32.msi
。
- 选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,选择“Custom”,按 next 键继续。
- 点选 Browse,手动指定安装目录。
- 填上安装目录,我的是
D:\Program Files (x86)\MySQL\MySQL Server 5.0
,按 OK 继续。
- 确认一下先前的设置,如果有误,按 Back 返回重做。按 Install 开始安装。
- 正在安装中,请稍候,直到出现下面的界面, 则完成MySQL的安装。
注意: 数据库安装好了还需要对数据库进行配置才能使用 MySQL的配置。
- 安装完成了,出现如下界面将进入MySQL配置向导。
- 选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标准配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。
- 选择服务器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(服务器类型,mysql占用较多资源)”、“Dedicated MySQL Server Machine(专门的数据库服务器,mysql占用所有可用资源)”。
- 选择MySQL数据库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(服务器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional)”,按 Next 继续。
- 选择网站并发连接数,同时连接的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设置,自己输一个数)”。
- 是否启用TCP/IP连接,设定端口,如果不启用,就只能在自己的机器上访问MySQL数据库了,在这个页面上,您还可以选择“启用标准模式(Enable Strict Mode)”,这样MySQL就不会允许细小的语法错误。如果是新手,建议您取消标准模式以减少麻烦。但熟悉MySQL以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按 Next 继续。
- 就是对MySQL默认数据库语言编码进行设置(重要),一般选UTF-8,按 Next 继续。
- 选择是否将MySQL安装为Windows服务,还可以指定Service Name(服务标识名称),是否将MySQL的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的文件,而不用指出目录名,比如连接,
mysql.exe -uusername -ppassword;
就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按 Next 继续。
- 询问是否要修改默认root用户(超级管理)的密码。“Enable root access from remote machines(是否允许root用户在其它的机器上登陆,如果要安全,就不要勾上,如果要方便,就勾上它)”。最后“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连接数据库,不能操作数据,包括查询)”,一般就不用勾了,设置完毕,按 Next 继续。
- 确认设置无误,按 Execute 使设置生效,即完成MySQL的安装和配置。
注意: 设置完毕,按 Finish 后有一个比较常见的错误,就是不能“Start service”,一般出现在以前有安装MySQL的服务器上,解决的办法,先保证以前安装的MySQL服务器彻底卸载掉了;不行的话,检查是否按上面一步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将MySQL安装目录下的data文件夹备份,然后删除,在安装完成后,将安装生成的 data文件夹删除,备份的data文件夹移回来,再重启MySQL服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。
解决方法: 卸载MySQL,重装MySQL。
2.2.2 Mac OS下安装
- 运行
mysql-5.5.40-osx10.6-x86_64.dmg
开始安装; - 下载完成后就一路安装,随后在“系统偏好设置”中打开MySQL服务:
2.3 卸载
2.3.1 Windows下卸载
- 停止Window的MySQL服务: 找到
控制面板 -> 管理工具 -> 服务
,停止MySQL后台服务。
- 去MySQL的安装目录找到my.ini文件,查找到
datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"
。
- 卸载MySQL: 找到
控制面板 -> 程序和功能
,卸载MySQL程序。
- 删除
C:/ProgramData/MySQL
目录(目录是隐藏文件,需要显示出来)
2.3.2 Mac OS下安装
- 关闭MySQL服务:
- 卸载:
brew remove mysql brew cleanup sudo rm /usr/local/mysql sudo rm -rf /usr/local/var/mysql sudo rm -rf /usr/local/mysql* sudo rm ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist sudo rm -rf /Library/StartupItems/MySQLCOM sudo rm -rf /Library/PreferencePanes/My* launchctl unload -w~/Library/LaunchAgents/homebrew.mxcl.mysql.plist edit /etc/hostconfig and remove the line MYSQLCOM=-YES- rm -rf ~/Library/PreferencePanes/My* sudo rm -rf /Library/Receipts/mysql* sudo rm -rf /Library/Receipts/MySQL* sudo rm -rf /private/var/db/receipts/*mysql*
2.4 配置
2.4.1 MySQL服务启动
- Windows服务方式启动:
或者cmd -> services.msc
打开“服务”窗口:
- DOS命令方式启动:
- 使用管理员打开cmd:
net start mysql
:启动mysql的服务
net stop mysql
:关闭mysql服务
- 使用管理员打开cmd:
2.4.2 MySQL登录
MySQL是一个需要账户名密码登录的数据库,登陆后使用,它提供了一个默认的root账号,使用安装时设置的密码即可登录。在控制台输入命令:
mysql -u用户名 -p密码
:先输入密码
mysql -u用户名 -p
:后输入密码
mysql -hIP地址 -u用户名 -p密码
:通过IP地址远程访问
mysql --host=IP地址 --user=用户名 --password=密码
:通过IP地址远程访问
2.4.3 MySQL退出
exit
或quit
2.4.4 MySQL目录结构
- MySQL安装目录:
basedir="D:/develop/MySQL/"
- MySQL数据目录:
datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"
- bin目录: 用于放置一些可执行文件,如mysql.exe、mysqld.exe、mysqlshow.exe等。
- data目录: 用于放置一些日志文件以及数据库。
- include目录: 用于放置一些头文件,如:mysql.h、mysql_ername.h等。
- lib目录: 用于放置一系列库文件。
- share目录: 用于存放字符集、语言等信息。
- my.ini: MySQL数据库中使用的配置文件。
- my-huge.ini: 适合超大型数据库的配置文件。
- my-large.ini: 适合大型数据库的配置文件。
- my-medium.ini: 适合中型数据库的配置文件。
- my-small.ini: 适合小型数据库的配置文件。
- my-template.ini: 是配置文件的模板,MySQL配置向导将该配置文件中选择项写入到my.ini文件。
- my-innodb-heavy-4G.ini: 表示该配置文件只对于InnoDB存储引擎有效,而且服务器的内存不能小于4GB。
2.5 数据库管理系统、数据库和表的关系
数据库管理程序(DBMS)可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。为保存应用中实体的数据,一般会在数据库创建多个表,以保存程序中实体User的数据。
数据库管理系统、数据库和表的关系如图所示:
- 一个数据库服务器包含多个数据库(文件夹)
- 一个数据库包含多张表(文件)
- 一张表包含多条记录(数据)