MySQL基础
Posted bigdata_devops
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL基础相关的知识,希望对你有一定的参考价值。
一 数据库是什么
数据库:即存储数据的仓库,(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
[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
mariadb数据库的相关命令是:
systemctl start mariadb #启动MariaDB
systemctl stop mariadb #停止MariaDB
systemctl restart mariadb #重启MariaDB
systemctl enable 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 user、drop 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以上是关于MySQL基础的主要内容,如果未能解决你的问题,请参考以下文章
[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础
连接MySQL出现错误:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)(代码片段
使用 json rereiver php mysql 在片段中填充列表视图
关于mysql驱动版本报错解决,Cause: com.mysql.jdbc.exceptions.jdbc4Unknown system variable ‘query_cache_size(代码片段