首页 > 技术文章 > MySQL基础

bingabcd 2017-06-04 21:53 原文

一 数据库是什么

数据库:即存储数据的仓库,(database,DB)是指长期存储在计算机内的,有组织,可共享的数据的集合。数据库中的数据按一定的数学模型组织、描述和存储,具有较小的冗余,较高的数据独立性和易扩展性,并可为各种用户共享。

 

二 为什么要有数据库

数据的存储方式依次经历了

三 数据库技术构成

1.数据库系统DBS

DBMS(DataBase Management System):MySQL,SQL Server,Oracle,DB2,mariadb

RDBMS((Relational Database Management System):上述DBMS被称之为关系型数据库

2.SQL语句

  • DDL语句:数据库定义语言,库、表、视图、索引、存储过程,包含create DROP ALTER语句
  • DML语句:数据库操纵语言,包含INSERT,DELETE,UPDATE,SELECT(增删改查)
  • DCL语句:数据库控制语言。包含GRANT,REVOKE等  (GRANT赋予用户权限,REVOKE取消用户权限)

3.数据库访问技术

  • JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API
  • ODBC(Open Database Connectivity,开放数据库连接)它建立了一组规范,并提供了一组对数据库访问的标准API(应用程序编程接口),ODBC本身也提供了对SQL语言的支持,用户可以直接将SQL语句送给ODBC。

四 MySQL及其他数据库介绍

Mysql是最流行的关系型数据库管理系统之一,在WEB应用方面MySQL是最好的RDBMS:关系数据库管理系统)应用软件之一。由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

  • Mysql是开源的,体积小,适用于linux平台,一般用于网站设计和小型软件。。
  • MySQL使用标准的SQL数据语言形式。
  • 使用c和c++编写 保证源代码的可移植性。支持多种操作系统 linx,mac os,freeBSD,windos,aix...
  • 为多种语言提供了api,包括(C C++ java php python等)
  • 支持tcp/ip,ODBC和JDBC等多种数据的连接途径
  • 支持多线程,充分利用cpu资源
  • 支持多种存储引擎(MyISAM、InnoDB、MEMORY等)
  • Mysql对PHP有很好的支持,PHP+mysql 被誉为完美结合。。
  • MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB。
  • Mysql是可以定制的,采用了GPL协议,你可以修改源码来开发自己的Mysql系统。

缺点:
相对于oracle DB2 SQLserver来讲规模小,功能有限(mysql cluster的功能和效率比较差)

 

在异常处理等方面还有待提升。
与其他数据库对比:

SQL server 是Microsoft的数据库,上手容易,简单,非常适合新手。一般用于.net 程序设计

oracle 是大型的关系型数据库,体积大。可以支持多个实例同时运行,功能非常强大;(所有的问题都用一个方案解决,效率低)

数据库管理系统软件

数据库管理系统(Database Management System)是一种操纵和管理数据库的大型软件,用于建立、使用和维护数据库,简称DBMS。它对数据库进行统一的管理和控制,以保证数据库的安全性和完整性。用户通过DBMS访问数据库中的数据,数据库管理员也通过dbms进行数据库的维护工作。它可使多个应用程序和用户用不同的方法在同时或不同时刻去建立,修改和询问数据库。大部分DBMS提供数据定义语言DDL(Data Definition Language)数据操作语言DML(Data Manipulation Language),供用户定义数据库的模式结构与权限约束,实现对数据的追加、删除等操作。

数据库管理系统是数据库系统的核心,是管理数据库的软件。数据库管理系统就是实现把用户意义下抽象的逻辑数据处理,转换成为计算机中具体的物理数据处理的软件。有了数据库管理系统,用户就可以在抽象意义下处理数据,而不必顾及这些数据在计算机中的布局和物理位置。

常见的数据库管理软件:甲骨文的oracle,IBM的db2,sql server, Access,Mysql(开源,免费,跨平台).

数据库系统

数据库系统DBS(Data Base System,简称DBS)通常由软件、数据库和数据管理员组成。其软件主要包括操作系统、各种宿主语言、实用程序以及数据库管理系统。数据库由数据库管理系统统一管理,数据的插入、修改和检索均要通过数据库管理系统进行。数据管理员负责创建、监控和维护整个数据库,使数据能被任何有权使用的人有效使用。

                        

 

五 MySQL安装及管理

安装

linux:

--yum -y install mariadb mariadb-server
OR
--yum -y install mysql mysql-server

win:

--http://dev.mysql.com/downloads/mysql/ 

启动

--service mysqld start  #开启(centos 6)
--chkconfig mysqld on   #设置开机自启 
OR
--systemctl start mariadb(CentOS 7)
--systemctl enable mariadb

查看

-- ps aux |grep mysqld    #查看进程
-- netstat -an |grep 3306 #查看端口

设置密码

1 mysqladmin -uroot password '123'#设置初始密码,初始密码为空因此-p选项没有用
2 mysqladmin -u root -p123 password '1234' #修改root用户密码

登录

-- mysql               #本地登录,默认用户root,空密码,用户为root@127.0.0.1
-- mysql -uroot -p1234 #本地登录,指定用户名和密码,用户为root@127.0.0.1
-- mysql -uroot -p1234 -h 192.168.31.95 #远程登录,用户为root@192.168.31.95    -h是host的意思  

mysql的常用命令

-- 
-- 启动mysql服务与停止mysql服务命令:
-- 
-- net start mysql
-- net stop  mysql
-- 
-- 
-- 登陆与退出命令:
-- 
--    mysql -h 服务器IP -P 端口号(Port 大写) -u  用户名 -p 密码(password 小写) --prompt 命令提示符  --delimiter 指定分隔符   
--    mysql -h 127.0.0.1 -P 3306 -uroot -p123
--    quit------exit----\q;
-- 
-- 
-- \s;   ------my.ini文件:[mysql] default-character-set=gbk [mysqld] character-set-server=gbk
-- 
-- prompt 命令提示符(\D:当前日期 \d:当前数据库  \u:当前用户)
-- 
-- \T(开始日志) \t(结束日志)
-- 
-- show warnings;
-- 
-- help() ? \h
-- 
-- \G;
-- 
-- select now();
-- select version();
-- select user;
-- 
-- \c 取消命令
-- 
-- delimiter 指定分隔符

忘记密码怎么办?

方法1:启动mysql时,跳过授权表

[root@controller ~]# service mysqld stop   (centos 6.x)
[root@controller ~]# mysqld_safe --skip-grant-table &
[root@controller ~]# mysql
mysql> select user,host,password from mysql.user;
+----------+-----------------------+-------------------------------------------+
| user     | host                  | password                                  |
+----------+-----------------------+-------------------------------------------+
| root     | localhost             | *A4B6157319038724E3560894F7F932C8886EBFCF |
| root     | localhost.localdomain |                                           |
| root     | 127.0.0.1             |                                           |
| root     | ::1                   |                                           |
|          | localhost             |                                           |
|          | localhost.localdomain |                                           |
| root     | %                     | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
+----------+-----------------------+-------------------------------------------+
mysql> update mysql.user set password=password("123") where user="root" and host="localhost";
mysql> flush privileges;
mysql> exit
[root@controller ~]# service mysqld restart
[root@controller ~]# mysql -uroot -p123
centos 6.x跳过授权表修改MySQL root密码
[root@controller ~]# systemctl stop mariadb  #停止MariaDB
[root@controller ~]# mysqld_safe --skip-grant-table &
[root@controller ~]# mysql
mysql> select user,host,password from mysql.user;
+----------+-----------------------+-------------------------------------------+
| user     | host                  | password                                  |
+----------+-----------------------+-------------------------------------------+
| root     | localhost             | *A4B6157319038724E3560894F7F932C8886EBFCF |
| root     | localhost.localdomain |                                           |
| root     | 127.0.0.1             |                                           |
| root     | ::1                   |                                           |
|          | localhost             |                                           |
|          | localhost.localdomain |                                           |
| root     | %                     | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
+----------+-----------------------+-------------------------------------------+
mysql> update mysql.user set password=password("123") where user="root" and host="localhost";
mysql> flush privileges;
mysql> exit
[root@controller ~]# service mysqld restart
[root@controller ~]# mysql -uroot -p123
centos 7跳过授权表修改MySQL root密码
mariadb数据库的相关命令是:

systemctl start mariadb  #启动MariaDB

systemctl stop mariadb  #停止MariaDB

systemctl restart mariadb  #重启MariaDB

systemctl enable mariadb  #设置开机启动
mariadb启动停止命令

方法2:删除与权限相关的库mysql,所有的授权信息都丢失,主要用于测试数据库或者刚刚建库不久没有授权数据的情况(从删库到跑路)

#方法二:
[root@controller ~]# rm -rf /var/lib/mysql/mysql
[root@controller ~]# service mysqld restart
[root@controller ~]# mysql

六 sql语句

库操作

语法
create database 数据库名;
数据库命名规则:
首字符是字母,其余部分可以是字母、数字、下划线、@、$
不能是关键字,如create database create
最长128位
不能是纯数字
#号代表注释

创建数据库
mysql> create database school charset utf8;
Query OK, 1 row affected (0.00 sec)

查看
mysql> show create database school;
+----------+-----------------------------------------------------------------+
| Database | Create Database                                                 |
+----------+-----------------------------------------------------------------+
| school   | CREATE DATABASE `school` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+-----------------------------------------------------------------+
row in set (0.00 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema | #虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数(用户表信息,列信息,权限信息,字符信息),存放于内存中
| mysql              | #授权库,存放mysql所有的授权信息
| performance_schema | #存放mysql服务的性能参数
| school             |
| test               | #测试库
+--------------------+
rows in set (0.00 sec)

选择数据库
mysql> use school;
Database changed
mysql> select database(); #查看当前use了哪个库
+------------+
| database() |
+------------+
| school     |
+------------+
row in set (0.00 sec)

修改
mysql> alter database school charset gbk;
Query OK, 1 row affected (0.00 sec)

mysql> show create database school;
+----------+----------------------------------------------------------------+
| Database | Create Database                                                |
+----------+----------------------------------------------------------------+
| school   | CREATE DATABASE `school` /*!40100 DEFAULT CHARACTER SET gbk */ |
+----------+----------------------------------------------------------------+

删除
mysql> drop database school;
Query OK, 0 rows affected (0.00 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
rows in set (0.00 sec)
库操作

表操作

建表:一张表必须属于一个库
表分成:标题+记录,标题也称为字段
id   hostname           port    #三个字段
1    webserver01        8080    #下面的都是表中的记录
2    webserver02        8081
3    database01         3306
4    LB_01              80
5    webapp01           9000
6    dns01              53

语法:
create table 表名(
    字段名1 类型(宽度) 约束条件,
    字段名2 类型(宽度) 约束条件,
    字段名3 类型(宽度) 约束条件,
);
注意:
同一张表中,字段名不能相同
字段名和类型必须有
宽度和约束条件为可选项
建表
#新建表
mysql> create database egon charset utf8;
Query OK, 1 row affected (0.00 sec)

mysql> use egon;
Database changed
mysql> create table host(
    -> id int(10),
    -> hostname char(20),
    -> port int(5)
    -> );
Query OK, 0 rows affected (0.02 sec)
新建表
#查看
mysql> show create table host; #查看刚刚新建的表详细信息
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                             |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------+
| host  | CREATE TABLE `host` (
  `id` int(10) DEFAULT NULL,
  `hostname` char(20) DEFAULT NULL,
  `port` int(5) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> desc host; #查看表结构
+----------+----------+------+-----+---------+-------+
| Field    | Type     | Null | Key | Default | Extra |
+----------+----------+------+-----+---------+-------+
| id       | int(10)  | YES  |     | NULL    |       |
| hostname | char(20) | YES  |     | NULL    |       |
| port     | int(5)   | YES  |     | NULL    |       |
+----------+----------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> show tables; #查看当前库下有多少表
+----------------+
| Tables_in_egon |
+----------------+
| host           |
+----------------+
1 row in set (0.00 sec)

mysql> select id,port,hostname from host; #查看,按照id,port,hostname的顺序
Empty set (0.00 sec)

mysql> select * from host; #查看所有,按照表中字段的顺序
Empty set (0.00 sec)

mysql> select id from host; #只查看id
Empty set (0.00 sec)
查看表信息
#插入内容
#语法:
insert into 表名(字段1,字段2,字段3...) values(值1,值2,值3)

单条插入
mysql> insert into host(id,hostname,port) values(1,'webapp01',8080);
Query OK, 1 row affected (0.01 sec)

多条插入
mysql> insert into host(id,hostname,port) values
    -> (2,'webapp02',8081),
    -> (3,'webapp03',8082),
    -> (4,'LB_01',80);
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

指定插入
mysql> insert into host(hostname) values ('LB_02');
Query OK, 1 row affected (0.00 sec)

查看刚刚插入的数据
mysql> select * from host;
+------+----------+------+
| id   | hostname | port |
+------+----------+------+
|    1 | webapp01 | 8080 |
|    2 | webapp02 | 8081 |
|    3 | webapp03 | 8082 |
|    4 | LB_01    |   80 |
| NULL | LB_02    | NULL |
+------+----------+------+
5 rows in set (0.00 sec)
插入数据

 

数据库常用操作:

DML:(data manipulation language,数据操纵语言):insert delete update select(增删改查);
DDL:(data definition language,数据定义语言):DDL比DML要多,主要命令有CREATE、ALTER、DROP,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用;
DCL:(Data Control Language,数据控制语言):是数据控制语言,是用来设置或者更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人
员才有权力执行DCL。
数据库操作(DDL)
1.创建数据库。(windows)
create database 数据库名;
use 数据库名;

表常用操作:
create table 表名; 创建表
delete from 表名; 清空表,但是不清楚索引
truncate 表名; 清空表和索引
drop 表名;删除表

举例:
CREATE TABLE employee(
id TINYINT PRIMARY KEY auto_increment,
name VARCHAR(25),
gender boolean,
age INT,DEFAULT 19,
department VARCHAR(20),
salary DOUBLE(7,2)
)


insert into 表名
INSERT INTO emp (name,salary,depart) VALUES ("xialv",30000,"python"),
("小雨",5000,"销售部"),
("冰冰",9000,"销售部");


delete



update


select
select * from 表名;


DECIMAL:数字类型

char 速度快(sql优化)
创建数据表定长的往前放,变长的往后放


enum枚举类型

外键的优点:节省内存

MariaDB [school]> create user 'li'@'192.168.11.139' identified by '123456';
Query OK, 0 rows affected (0.01 sec)

MariaDB [school]> grant all privileges on db1.t1 to 'li'@'%';
Query OK, 0 rows affected (0.01 sec)

[root@python-web2 ~]# mysql -uli -h 192.168.11.139 -p
输入li的密码123456

数据库操作

1、显示数据库

SHOW DATABASES;

默认数据库:
  mysql - 用户权限相关数据
  test - 用于用户测试数据
  information_schema - MySQL本身架构相关数据

2、创建数据库

# utf-8
CREATE DATABASE 数据库名称 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
 
# gbk
CREATE DATABASE 数据库名称 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

3、使用数据库

USE db_name;

显示当前使用的数据库中所有表:SHOW TABLES;

4、用户管理

创建用户
    create user '用户名'@'IP地址' identified by '密码';
删除用户
    drop user '用户名'@'IP地址';
修改用户
    rename user '用户名'@'IP地址'; to '新用户名'@'IP地址';
修改密码
    set password for '用户名'@'IP地址' = Password('新密码');
PS:用户权限相关数据保存在mysql数据库的user表中,所以也可以直接对其进行操作(不建议)

5、授权管理

show grants for '用户'@'IP地址'                  -- 查看权限
grant  权限 on 数据库.表 to   '用户'@'IP地址'      -- 授权
revoke 权限 on 数据库.表 from '用户'@'IP地址'      -- 取消权限
all privileges  除grant外的所有权限
            select          仅查权限
            select,insert   查和插入权限
            ...
            usage                   无访问权限
            alter                   使用alter table
            alter routine           使用alter procedure和drop procedure
            create                  使用create table
            create routine          使用create procedure
            create temporary tables 使用create temporary tables
            create user             使用create userdrop user、rename user和revoke  all privileges
            create view             使用create view
            delete                  使用delete
            drop                    使用drop table
            execute                 使用call和存储过程
            file                    使用select into outfile 和 load data infile
            grant option            使用grant 和 revoke
            index                   使用index
            insert                  使用insert
            lock tables             使用lock table
            process                 使用show full processlist
            select                  使用select
            show databases          使用show databases
            show view               使用show view
            update                  使用update
            reload                  使用flush
            shutdown                使用mysqladmin shutdown(关闭MySQL)
            super                   

推荐阅读