###一键偷懒YUM安装MySQbL###

1.安装mysql数据库

#yum install -y mariadb-server  mariadb

2.登录mysql数据库常用选项

  -h:指定服务端主机地址
  -u: 指定登入的用户名
  -p:指明密码
  -D:指明登入的数据库
  -e:连接之后直接运行SQL语句,不进入交互式模式(可以在脚本中使用)

3.mysql语言分为3大类

  DDL:数据库定义语言  create , alter , drop

  DML:数据库操作语言  insert , delete , update , select

  DCL:数据库控制语言  grant , revoke

4.数据库DDL语言

  创建库  create database zxxsql;

  删除库  drop database zxxsql;
  修改库   alter database zxxsql character set = utf8

  创建表    create table home (id int not null primary key auto_increment, name varchar(250) not null, class varchar(250) not null);
  
查看表结构    desc home;
  
修改表
      
添加字段:alter table home add gender enum('f','m');
      
删除字段:alter table home drop gender;
      
修改字段
           alter table home change name username varchar(100) after id;
           alter table home modify username varchar(100) first;
  
删除表:drop table home;
5.数据库DML语言

  <1>insert     在home表中插入3组class和username数据。

    insert into home (class,username) values ('ops', '运维开发'), ('opsdev', '运维开发'), ('开发', 'java开发');

  <2>update     修改home表数据

    update home set class = '开发部门' where id = 1;

  <3>delete  删除表数据

    delete from home where class = '开发';

  <4>select

    查询表上的所有的数据   select * from home;
    查询部分数据  select id,class from home;
    # 还可以取个别名    select id as num,class from home;

    使用where子句过滤
      # 可以使用的算数运算符:>, < , >=, <=, ==, !=
      # 可以使用连接词:and , or
      select * from home where id >= 2;
      select * from home where id <= 2 and id >1;
      select * from home where id between 1 and 2;

    # 可以使用like做模糊匹配(%:表示任意长度的字符,_:表示任意单个字符)
    select * from home where class like 'ops%';

    # 可以使用null对值进行判断
    select * from home where id is not null;
    select * from home where id is null;

    使用order指定排序(默认是asc,升序排列)
    select * from home order by id desc;

6.DCL数据库语言

  <1>grant

    #先创建用户,再授权

    create user zxx@'172.16.19.%' identified by '123456';

    grant all on *.* to zxx@'172.16.19.%';
    flush privileges;
    #
创建用户的同时给用户授权
    grant all on *.* to zxx@'172.16.19.%' identified by '123456';
    flush privileges;
    #给用户授予某些权限
    show grants for zxx@'172.16.19.%';

  <2>查看用户权限

    show grants for zxx@'172.16.19.%';

  <3>删除用户

    delete from mysql.user where user = "zxx";
    flush privileges;

7.select 查询语句详解

  -1:where子句:指明过滤条件
    可以使用的算数运算符:+, -, * ,/ ,= ,!= ,<=, >=
    between 较小的数 and 较大的数
    in (较小的数,较大的数)
    is null 或 is not null
    like模糊匹配
    例如:
    select * from home where id >= 2;
    select * from home where id <= 2 and id >1;
    select * from home where id between 1 and 2;
    select * from home where id in (1,2); # 从1和2中取值
    select * from home where class like 'ops%';
    select * from home where id is not null;
    select * from home where id is null;

  -2:group by 子句:根据指定的查询条件将查询结构进行分组,用于做聚合运算
    使用聚合函数:avg( ) , max( ) , min( ) , count( ), sum( )
    select age,gender from students group by gender;
    select avg(age),gender from students group by gender;
    select min(age), gender from students group by gender;
    select max(age), gender from students group by gender;
    select count(id), gender from students group by gender;

  -3:having子句:将分组之后的结果再次过滤
    select avg(age) as 'average_age', gender from students group by gender having average_age > 50;

  -4:order by子句 :根据指定的字段对查询结果进行排序,默认为升序,降序使用关键字desc
    select name,age from students order by age desc;

  -5:limit 子句:对查询的结果进行输出行数的限制
    select name,age from students order by age desc limit 8; # 选前8行
    select name,age from students order by age limit 4, 2; # 前4个不选,从第五行开始选2行

###总结单表查询次序##########################################################################################################################

子句的书写顺序:
where -> group by -> having -> order by -> limit

例如:                                                              
select *,avg(score) as '各班平均成绩' from students where id > 1 group by class having avg(score) > 55 order by score desc limit 3 ;  #

#############################################################################################################

my_mysql的更多相关文章

  1. mysqli_set_charset和SET NAMES优劣分析

    bool mysqli_set_charset ( mysqli $link , string $charset ) 这应该是首选的用于改变字符编码的方法,不建议使用 mysqli_query()执行 ...

  2. linux一些工具的安装(三)

    linux(vmware15   centos7)中Docker安装 一.Docker卸载 1.查看已安装的docker安装包 $yum list installed|grep docker 执行后的 ...

  3. Docker: 创建带数据的MySql container

    如果需要想要在一个装有docker的机器上启动一个MySql的container,并且整个MySql container有我想要的数据: 1. 先在已有的MySql instance上准备好数据 2. ...

  4. Docker容器学习梳理 - 应用程序容器环境部署

    关于国内Docker镜像,可以参考:Docker容器学习梳理--基础知识(2) 的Docker镜像使用. 如果我们需要在Docker环境下部署tomcat.redis.mysql.nginx.php等 ...

  5. cenos7.0 安装docker

    使用yum命令在线安装  yum install docker 安装后查看Docker版本 docker -v启动docker:systemctl start docker停止docker:syste ...

  6. PHP API中,MYSQL与MYSQLI的持久连接区别

    转载自:http://www.cnxct.com/some-differences-between-mysql-and-mysqli-of-persistent-connection/ 很久很久以前, ...

  7. Python爬虫(八)

    源码: import requests import re from my_mysql import MysqlConnect import time,random # 获取招聘详情链接 def ge ...

  8. Python爬虫(七)

    源码: import requests import re from my_mysql import MysqlConnect # 获取详情页链接和电影名称 def get_urls(page): u ...

  9. Python爬虫(六)

    源码: import requests import re from my_mysql import MysqlConnect # 获取问答信息 def get_contents(page,heade ...

随机推荐

  1. 用于数组的delete p324

    delete 对象地址; delete 首先调用待清除对象的析构函数,然后释放内存 如果delete一个void指针,唯一发生的事情就是释放了内存.因为通过void指针,无法知道对象的类型,就无法调用 ...

  2. H3C 动态路由协议的基本原理

  3. UVA 12563 "Jin Ge Jin Qu hao" (背包)

    传送门 debug了好一会,突然发现,输出错了,emmm......... 明天再写debug历程: (PS:ipad debug是真的繁琐) 题意: 题解: 尽管题干中给的 t 的范围很大,但是 t ...

  4. ESB总线的核心架构

    根据近期对开源ESB产品的研究,已经对Oracle和Tibco的ESB总线产品的实施经验积累,对ESB总线的核心产品架构有了进一步的清晰认识,将ESB的核心架构整理为上图,上图中看到的内容也是做为一款 ...

  5. asp dotnet core 图片在浏览器没访问可能原因

    我写了一个项目用来广告就用到广告的图片,但是广告的图片放在博客的链接无法访问,连我的方法都没有调用,而我尝试网页直接访问图片链接是可以访问的,最后找到原因是广告插件禁用了图片访问 我在一个方法创建了广 ...

  6. linux 重用 short 为 I/O 内存

    short 例子模块, 在存取 I/O 端口前介绍的, 也能用来存取 I/O 内存. 为此, 你必须告 诉它使用 I/O 内存在加载时; 还有, 你需要改变基地址来使它指向你的 I/O 区. 例如, ...

  7. JS的防抖与节流学习笔记

    防抖(debounce):当持续触发事件时,在一定的时间段内,只有最后一次触发的事件才会执行. 例: function debounce(fn, wait) { var timer = null; r ...

  8. 1119 机器人走方格 V2 (组合数学)

    M * N的方格,一个机器人从左上走到右下,只能向右或向下走.有多少种不同的走法?由于方法数量可能很大,只需要输出Mod 10^9 + 7的结果.   Input 第1行,2个数M,N,中间用空格隔开 ...

  9. C语言 屏幕截图 (GDI)

    截取全屏幕 #include <windows.h>   void echo(CHAR *str); int CaptureImage(HWND hWnd, CHAR *dirPath, ...

  10. HttpRepl 互操作的 RESTful HTTP 服务调试命令行工具

    今天早上曽根セイラ告诉我一个好用的工具 HttpRepl 这是一个可以在命令行里面对 RESTful 的 HTTP 服务进行路由跳转和访问的命令行工具.可以使用 cd 这个命令和像文件跳转已经跳转到下 ...