|
|
51CTO旗下网站
|
|
移动端

MySQL数据库基础篇之入门基础命令

在日常工作与学习中,无论是开发、运维、还是测试,对于数据库的学习是不可避免的,同时也是日常工作的必备技术之一。

作者:民工哥技术之路来源:segmentfault|2019-10-12 15:06

在日常工作与学习中,无论是开发、运维、还是测试,对于数据库的学习是不可避免的,同时也是日常工作的必备技术之一。在互bck官网注册账号申请公司,开源产品线比较多,互bck官网注册账号申请企业所用的数据库占比较重的还是MySQL。

在刚刚出炉的 2019 年3月份数据库流行度排行榜上,第一梯队的前三个数据库产品都获得了显着的加分增长。

其中 Oracle 上升了15.12分,MySQL上升了30.96分,SQL Server则上升了 7.79分。以下是前20位的数据库榜单:

所以,民工哥,将公众号所推送的MySQL数据库的文章,统一整理做成一个学习进阶的集合,在此分享给各位读者。各位读者朋友觉得文章对你在学习MySQL数据库的路上有所帮助,请动动小手转发分享出去。让更多的小伙伴们一起参与学习,大家共同成长,一起奔跑在技术的路上。

有需要加入民工哥组建的技术交流群的读者朋友们,可在公众号后台回复:「加群」

数据——公司的生命线,因此在大多数的互bck官网注册账号申请公司,都在使用开源的数据库产品,MySQL也因此关注度与使用率非常的高,所以做为运维的屌丝们,掌握它的一些基本操作还是必要的,那么今天就来侃一侃一些常用的基础命令,走过的、路过的,就不要再错过了,掌握的、没掌握的,也不要再扔民工哥鸡蛋了哦,呵呵.........

从此篇文章开始将要给大家带来另一个系列的文章:Mysql数据库系列,总共分为以下四个大类:

1、基础篇

2、中级篇

3、优化篇

4、企业架构篇

1、使用帮助信息

登陆数据库就不介绍了哦,比如说想做创建的数据库的操作,不知道命令,就可以查看帮助信息

  1. mysql> help create;  
  2. Many help items for your request exist.  
  3. To make a more specific request, please type 'help <item>',  
  4. where <item> is one of the following  
  5. topics:  
  6.    CREATE DATABASE   #最简单的创建命令  
  7.    CREATE EVENT  
  8.    CREATE FUNCTION  
  9.    CREATE FUNCTION UDF  
  10.    CREATE INDEX  
  11.    CREATE LOGFILE GROUP  
  12.    CREATE PROCEDURE  
  13.    CREATE SERVER  
  14.    CREATE TABLE  
  15.    CREATE TABLESPACE  
  16.    CREATE TRIGGER  
  17.    CREATE USER  
  18.    CREATE VIEW  
  19.    SHOW  
  20.    SHOW CREATE DATABASE  
  21.    SHOW CREATE EVENT  
  22.    SHOW CREATE FUNCTION  
  23.    SHOW CREATE PROCEDURE  
  24.    SHOW CREATE TABLE  
  25.    SPATIAL 

2、创建、删除、查看数据库

  1. mysql> create database test_data;  
  2. #创建默认字符集的数据库(默认是拉丁字符集)  
  3. Query OK, 1 row affected (0.02 sec)  
  4. mysql> show databases like "test%";  
  5. +------------------+  
  6. | Database (test%) |  
  7. +------------------+  
  8. | test_data        |  
  9. +------------------+  
  10. 1 rows in set (0.00 sec) 

创建gbk字符集的数据库

  1. mysql> create database test_gbk DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;  
  2. Query OK, 1 row affected (0.04 sec)  
  3. mysql> show create database test_gbk;   
  4. #查看创建数据库的语句  
  5. +----------+----------------------------------------------+  
  6. | Database | Create Database                              |  
  7. +----------+------------------------------------------------------------------+  
  8. | test_gbk | CREATE DATABASE `test_gbk` /*!40100 DEFAULT CHARACTER SET gbk */ |  
  9. +----------+----------------------------------------------+  
  10. 1 row in set (0.00 sec) 

删除数据库

  1. mysql> drop database test_data;  
  2. Query OK, 0 rows affected (0.07 sec)  
  3. mysql> show databases;  
  4. +----------------------------+  
  5. | Database                   |  
  6. +----------------------------+  
  7. | information_schema |  
  8. | test_gbk                    |  
  9. +----------------------------+ 

3、连接数据库

  1. mysql> use test_gbk;  
  2. #相当于cd命令,切换到数据库进行操作  
  3. Database changed  
  4. mysql> select database();  
  5. #查看当前连接的数据库,相当于pwd  
  6. +------------+  
  7. | database() |  
  8. +------------+  
  9. | test_gbk   |  
  10. +------------+  
  11. 1 row in set (0.00 sec)  
  12. mysql> select user();  
  13. #查看当前连接数据库的用户,相当于whoami  
  14. +--------------------+  
  15. | user()               |  
  16. +-------------------+  
  17. | root@localhost |  
  18. +--------------------+  
  19. 1 row in set (0.00 sec) 

4、创建用户、授权、收回权限

当数据库创建完成后,就需要创建用户,以供需要连接数据库的人员使用与操作数据库,不可能人人使用root登陆,所以权限设置也是很重要的

  1. mysql> grant all on test_gbk.* to 'testuser'@'localhost' identified by '123456';  
  2. #创建用户并all权限给在test_gbk库所有表,密码‘123456’  
  3. Query OK, 0 rows affected (0.00 sec)  
  4. mysql> flush privileges;  
  5. #刷新权限,使权限生效  
  6. Query OK, 0 rows affected (0.00 sec)  
  7. mysql> show grants for 'testuser'@'localhost';  
  8. #查看用户有哪些权限  
  9. +-----------------------------------------------------------------------------------------------------------------+  
  10. | Grants for testuser@localhost                           |  
  11. +-----------------------------------------------------------------------------------------------------------------+  
  12. | GRANT USAGE ON *.* TO 'testuser'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |  
  13. | GRANT ALL PRIVILEGES ON `test_gbk`.* TO 'testuser'@'localhost'                                  |  
  14. +-----------------------------------------------------------------------------------------------------------------+  
  15. 2 rows in set (0.00 sec) 

收回权限

  1. mysql> revoke insert,update,select,delete on test_gbk.* from 'testuser'@'localhost';  
  2. #将以上权限收回  
  3. Query OK, 0 rows affected (0.00 sec)  
  4. mysql> show grants for 'testuser'@'localhost';            
  5. +----------------------------------------------------------------------------------------------------+  
  6. | Grants for testuser@localhost                           |  
  7. +----------------------------------------------------------------------------------------------------+  
  8. | GRANT USAGE ON *.* TO 'testuser'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9'           |  
  9. | GRANT CREATE, DROP, REFERENCES, INDEX, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, EVENT, TRIGGER ON `test_gbk`.* TO 'testuser'@'localhost' | 
  10. +------------------------------------------------------------------------------------------------------------------------------+ 
  11. 2 rows in set (0.00 sec) 

注:原来不知道all权限到底是哪些权限,采用这种方法之后,应该就清楚了

SELECT,INSERT, UPDATE, DELETE, CREATE, DROP, REFERENCES, INDEX, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, EVENT, TRIGGER

5、创建、删除表

  1. mysql> create table test(id int(4)not null,name char(20)not null);  
  2. #建表,并且建立两个字段  
  3. Query OK, 0 rows affected (0.06 sec)  
  4. mysql> show tables;#查看表  
  5. +--------------------+  
  6. | Tables_in_test_gbk |  
  7. +--------------------+  
  8. | test                     |  
  9. +--------------------+  
  10. 1 row in set (0.00 sec)  
  11. mysql> desc test; #查看表结构  
  12. +-------+----------+------+-----+---------+-------+  
  13. | Field | Type     | Null | Key | Default | Extra |  
  14. +-------+----------+------+-----+---------+-------+  
  15. | id    | int(4)   | NO   |     | NULL    |       |  
  16. | name  | char(20) | NO   |     | NULL    |       |  
  17. +-------+----------+------+-----+---------+-------+  
  18. 2 rows in set (0.01 sec)  
  19. mysql> create table test1(id int(4)not null,name char(20)not null);  
  20. Query OK, 0 rows affected (0.01 sec)  
  21. mysql> show tables;  
  22. +------------------------+  
  23. | Tables_in_test_gbk |  
  24. +------------------------+  
  25. | test                        |  
  26. | test1                     |  
  27. +--------------------+  
  28. 2 rows in set (0.00 sec) 

删除表

  1. mysql> drop tables test;  
  2. Query OK, 0 rows affected (0.00 sec)  
  3. mysql> show tables;  
  4. +--------------------+  
  5. | Tables_in_test_gbk |  
  6. +--------------------+  
  7. | test1                 |  
  8. +--------------------+  
  9. 1 row in set (0.00 sec) 

查看建表

  1. mysql> show create table test1\G  
  2. *************************** 1. row ***************************  
  3.        Table: test1  
  4. Create Table: CREATE TABLE `test1` (  
  5.   `id` int(4) NOT NULL,  
  6.   `name` char(20) NOT NULL  
  7. ENGINE=MyISAM DEFAULT CHARSET=gbk  
  8. 1 row in set (0.00 sec) 

基础的操作命令就介绍这么多,都是一些常用的必备命令

关注 民工哥技术之路 微信公众号对话框回复关键字:1024 可以获取一份最新整理的技术干货:包括系统运维、数据库、redis、MogoDB、电子书、Java基础课程、Java实战项目、架构师综合教程、架构师实战项目、大数据、Docker容器、ELK Stack、机器学习、BAT面试精讲视频等。

【编辑推荐】

  1. 面试官出的MySQL索引问题,这篇文章全给你解决!
  2. 详解Oracle数据库表空间设计--ASM/BFT/OMF综合使用
  3. 10月数据库排行:Microsoft SQL Server 分数增加最多
  4. 分享一份大佬的MySQL数据库设计规范,值得收藏
  5. 传统数据库不适合现代企业架构了?
【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

CentOS 8 全新学习术

CentOS 8 全新学习术

CentOS 8 正式发布
共16章 | UbuntuServer

115人订阅学习

用Python玩转excel

用Python玩转excel

让重复操作傻瓜化
共3章 | DE8UG

204人订阅学习

AI入门级算法

AI入门级算法

算法常识
共22章 | 周萝卜123

166人订阅学习

视频课程+更多

Excel企业实战与解决方案开发教程1

Excel企业实战与解决方案开发教程1

讲师:王子宁230678人学习过

VMware vSphere  VCP 6.5 | 6.7 (附加Horizon 7.6)

VMware vSphere VCP 6.5 | 6.7 (附加Horizon

讲师:郝旺251954人学习过

小白轻松学Spring Cloud

小白轻松学Spring Cloud

讲师:齐毅79775人学习过

读 书 +更多

网管员必读——网络基础(第2版)

本书是在《网管员必读—网络基础》(第1版)基础上修改而成的。全书共分9章,分别介绍计算机网络概述(修改)、数制(新增)、网络通信基础...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微