Linux运维:MySQL数据库(1)

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---

相关推荐
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据4 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡4 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧4 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon4 天前
SQL学习指南——视图
数据库·sql
活宝小娜4 天前
mysql详细安装教程
数据库·mysql·adb