1.信息与数据:
数据是信息的载体,信息是数据的内涵。数据库就是存储数据的仓库,并长期存储在计算机磁盘中,可由多个用户和应用程序共享的数据集合,就是数据库。
2.数据库中的数据的特点:
2.1.数据是按照某种结构组织的:数据的内部构成及对外联系就是数据库的"型",而数据的具体取值就是数据库的"值"。
2.2.数据具有整体性:即数据库中的数据是从整体出发,综合了各个应用程序和用户的需求,数据是整体结构化的。
2.3.数据有共享性、数据有较高的独立性:数据库中的数据和应用程序在物理和逻辑上均实现了分离,数据结构的该变不影响应用程序的运行,数据和程序具有较高的独立性。
3.数据库管理系统的功能
DBMS(数据库管理系统):是管理数据库的系统软件,它实现数据库系统的各种功能。是数据库系统的核心。数据库管理系统位于操作系统之上,通过调用操作系统的各种服务,为用户提供管理各种数据库对象的接口和各种方法,从而实现对数据的各种操作。DBMS的功能建立在操作系统的底层服务之上,数据库的管理控制及用户对数据的各种操作命令的执行均由DBMS实现。
数据库管理系统主要有三个功能:数据定义(DDL)、数据操纵(DML)、数据控制。
数据定义是定定义了数据库的各种对象,表,视图,索引,存储过程,触发器等。一般有create,drop,alter
数据操作是对数据表中的操作,如增、删、改、查、统计等各种存储操作。实现对数据库中数据的基本操作。一般有insert,delete,update等。
数据控制一般有grant,revoke。
数据查询语句:select
结构化查询语言(SQL)是一种专门用来与数据库通信的语言,其利用一些简单的句子构成基本的语法来存取数据库中的内容,便于用户从数据库中获得及操作所需数据。
SQL语言具有以下特点:(1)SQL语言是非过程化语言。(2)SQL语言是统一的语言。(3)SQL语言是关系型数据库的公共语言。
关系型数据库中的一个表是由行和列组成的,并且要求表中的每行记录必须唯一。在设计表时,可以通过定义主键(primary key)来保证记录(实体)的唯一性。关系型数据库一般是MySQL,SQL Server,access,DB2,sybase等等。关系型数据库结构是二维数据库表,二维表中每个字段用来描述对象的一个属性。每个记录用来描述一个对象的信息,关系数据写到哪里也就是存储在硬盘当中读写系统就会受到的IO限制或者瓶颈。非关系型数据库:NoSQL,Redis。它们都存储高热数据(在内存中高速运行),不同点:redis可以做持久化保存,可以存储对象。
一个表的主键由一个或多个字段组成,值具有唯一性,且不允许去控制,主键的作用是唯一的标识表中的每一条记录。
关系型数据库中的术语:
关系:关系就是二维表,其中表中的行、列次序并不重要
行row:表中的每一行,又称为一条记录或元组
列column:表中的每一列,称为属性或字段或域
主键primary key:用于唯一确定一个记录的字段,一张表只有一个主键,可以有多个外键
域domain:属性的取值范围,如:性别只能是"男"和"女"两个人,人类的年龄只能0-150
联系类型:一对一联系(1:1)、一对多联系(1:n)外键、多对多联系(n:n)三张表。
数据库的编译安装:
#创建一个目录/data/
[root@Node1 ~]#:mkdir /data ; cd /data/
#把源码包拖进来。
[root@Node1 data]#:ls
mysql-boost-5.7.20.tar.gz
#解压
[root@Node1 data]#:tar xf mysql-boost-5.7.20.tar.gz
[root@Node1 data]#:ls
mysql-5.7.20 mysql-boost-5.7.20.tar.gz
[root@Node1 data]#:cd /data/mysql-5.7.20/
#安装依赖包
[root@Node1 mysql-5.7.20]#:yum install -y ncurses-devel autoconf cmake
[root@Node1 mysql-5.7.20]#:yum -y install gcc gcc-c++ cmake bison bison-devel zlib-devel libcurl-devel libarchive-devel boost-devel ncurses-devel gnutls-devel libxml2-devel openssl-devel libevent-devel libaio-devel
#新建一个用户mysql,用于管理mysql
[root@Node1 mysql-5.7.20]#:useradd -M -s /sbin/nologin mysql
#编译安装:
[root@Node1 mysql-5.7.20]#:cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
[root@Node1 mysql-5.7.20]#:make -j4 #编译,4核。这里等待时间较长,约20分钟
[root@Node1 mysql-5.7.20]#:make install
数据库安装成功。给数据库mysql用户权限
#数据库目录进行权限调整
[root@localhost mysql-5.7.20]#:chown -R mysql:mysql /usr/local/mysql/
#建立调整配置文件
[root@localhost mysql-5.7.20]#:vim /etc/my.cnf
[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock
[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE
USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR
FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES #这里是一行
#修改配置文件权限
[root@localhost mysql-5.7.20]#:chown -R mysql:mysql /etc/my.cnf
#设置环境变量
[root@localhost mysql-5.7.20]#:echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
[root@localhost mysql-5.7.20]#:echo 'export PATH' >> /etc/profile
[root@localhost mysql-5.7.20]#:source /etc/profile
#初始化数据库,相对路径
[root@localhost mysql-5.7.20]#:cd /usr/local/mysql/
[root@localhost mysql]#:bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
#ls看一下,就会有一个data文件夹
#准备systemctl配置文件
[root@localhost mysql]#:cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system
[root@localhost mysql]#:systemctl daemon-reload
[root@localhost mysql]#:systemctl start mysqld
#可以查看状态,是否启动
[root@localhost mysql]#:systemctl status mysqld
#修改数据库密码
[root@localhost mysql]#:mysqladmin -u root -p password "abc123"
#直接回车
#登录数据库:
[root@localhost mysql]#:mysql -uroot -p"abc123"
登录成功!
ctrl + D退出登录
--end---
DDL和DML:以分号结尾;
1.显示所有数据库:show databases;
2.创建数据库:create database db1;
查看:多了一个数据库,其他的四个是系统中自带的数据库
3.创建表:
创建一个学生表student,包括学号ID,姓名name,性别sex,年龄age,电话号码phone,邮箱email。其中学号ID为int型,设置为主键。电话号码最长不超过11位,不为空。邮箱不超过30位,唯一。创建表要先进入数据库:use db1;
create table student (
id int primary key,
name varchar(10),
sex char(1),
age varchar(3),
phone varchar(11) not null,
email varchar(30) unique
);
Query OK, 0 rows affected (0.00 sec)
4.添加字段:
查看表结构:desc student;
如果再添加一个字段,使用alter,add添加。如,添加班级class,字符型,最长为10位。
alter table student add class varchar(10) not NULL;
5.修改字段名:
如果修改字段名:使用change修改。
如果将class修改成bj,语句:alter table student change class bj varchar(10) not NULL;
修改成功:
6.修改字段约束:
在改字段名的时候也可以指定新名字的字段约束,如将class改成bj并直接将varchar改成char。
如果在不修改字段名的情况下,直接修改字段约束:使用alter .. modify
alter table student modify bj char(5);
7.删除字段:
删除字段:使用alter ..drop:
如将bj字段删除掉:alter table student drop bj;
8.显示表:
必须use进入到一个数据库中,才能显示表:
show tables; 只创建了一张表student。
9.删除数据库:
通过语句:drop database db1;
db1的表已删除了。
---end---