文章目录
基本概念
组成
一、数据
- 描述事物的符号记录
- 包括数字,文字、图形、图像、声音、档案记录等
- 以“记录”形式按统一的格式进行存储
二、表
- 将不同的记录组织在一起
- 用来存储具体数据
三、数据库
- 表的集合,是存储数据的仓库
- 以一定的组织方式存储的相互有关的数据集合
管理系统和数据库系统
一、数据库管理系统(DBMS)
- DBMS是实现对数据库资源有效组织、管理和存取的系统软件
- 项目架构不是只有服务,还可以有一些通用的管理系统比如:nginx+tomcat+redis+mysql+nfs 管理系统:BOSS CRM
二、数据库系统
- 是一个人机系统,由硬件、OS、数据库、DBMS、应用软件和数据库用户组成
- 用户可以通过DBMS或应用程序操作数据库
作用
- 持久化存储
- 快速寻找到数据
数据库类型
数据库分为关系型数据库和非关系型数据库
关系型数据库
- 存储的往往是字符、字符串、数值、布尔值等
- 关系模型可用简单的“实体-关系-属性”来表示
- 关系模型的数据结构使用简单易懂的二维数据表
每一行称为一条记录,用来描述一个对象的信息
每一列称为一个字段,用来描述对象的一个属性 - 主流的关系型数据库有:Mysql(Oracle公司)、SQL server(微软)、access(微软公司office产品)、Oracle(甲骨文公司产品)等。
实体
实体也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”,如银行客户、银行账户等。
属性
属性是实体所具有的某一特性,一个实体可以有多个属性,如“银行客户”实体集中的每个实体均具有姓名、住址、电话等属性。
联系
实体集之间的对应关系称为联系,也称为关系,如银行客户和银行账户之间存在“储蓄”的关系。
应用举例
- 12306用户信息系统
- 淘宝账号系统
- 联通手机号信息系统
- 银行用户账号系统
- 网站用户信息系统
非关系型数据库
- 非关系型数据库也被称为NoSQL(Not Only SQL)
- 存储数据不以关系模型为依据,不需要固定的表格式
- 存储的一般是图片、视频、语音等,当然也能存储关系型数据库存储的内容。
- 非关系型数据库的优点:
数据库可高并发读写
对海量数据高效率存储与访问
数据库具有高扩展性与高可用性
MangoDB、Redis(内存数据库/缓存数据库)K-V键值对与类似的Memcache K-V键值对redis-memecache区别:
- 相同点:存储高热数据(在内存中高速运行)
- 不同点:redis可以做持久化保存,可以存储对象
Mysql数据库介绍
是一款Oracle旗下深受欢迎的开源关系型数据库,遵守GPL协议,可以免费使用与修改
特点
- 性能卓越、服务稳定
- 开源、无版权限制、成本低
- 多线程、多用户
- 基于C/S(客户端/服务器)架构
- 安全可靠
MySQL商业版与社区版区别
- MySQL商业版是由MySQL AB公司负责开发与维护,需要付费才能使用;社区版是由分散在世界各地的MySQL开发者、爱好者一起开发与维护,可以免费使用
- 商业版组织管理与测试环节更加严格,会比社区版更稳定
- 商业版不遵守GPL,社区版遵从GPL可以免费使用
- 商业版可获得7*24小时的服务,社区版则没有
Mysql与oracle的区别
区别 | Oracle | Mysql |
---|---|---|
本质的区别 | 是一个对象关系数据库管理系统 | 是一个开源的关系数据库管理系统 |
数据库安全性 | 使用了许多安全功能,如用户名,密码,配置文件,本地身份验证,外部身份验证,高级安全增强功能等 | 使用三个参数来验证用户,即用户名,密码和位置 |
字符数据类型 | 支持四种字符类型,即CHAR,NCHAR,VARCHAR2和NVARCHAR2; 所有四种字符类型都需要至少1个字节长; CHAR和NCHAR最大可以是2000个字节,NVARCHAR2和VARCHAR2的最大限制是4000个字节。可能会在最新版本中进行扩展 | 具有CHAR和VARCHAR,最大长度允许为65,535字节(CHAR最多可以为255字节,VARCHAR为65.535字节) |
数据库的认证难易程度 | 较难 | 较易 |
编译安装Mysql
MySQL数据库基本命令
常用的数据类型
- int :整型
- float :单精度浮点 4字节32位
- double :双精度浮点 8字节64位
- char :固定长度的字符类型
- varchar :可变长度的字符类型
- text :文本
- image :图片
- decimal(5,2) :5个有效长度数字,小数点后面有2位
查看数据库结构
SQL语句
SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。
分类
- DDL:数据定义语言,用于创建数据库对象,如库、表、索引等
- DML:数据操纵语言,用于对表中的数据进行管理
- DQL:数据查询语言,用于从数据表中查找符合条件的数据记录
- DCL:数据控制语言,用于设置或者更改数据库用户或角色权限
创建及删除数据库和表
管理表中的数据记录
向数据表中插入新的数据记录
查询数据记录
修改、更新数据表中的数据记录