一、下载

官网地址: https://dev.mysql.com/downloads/mysql/

选择:macOS 10.14 (x86, 64-bit), Compressed TAR Archive

下载后,得到一个131.9m的压缩包 mysql-8.0.13-macos10.14-x86_64.tar.gz,将其解压到/usr/local/下,并重命名为mysql (即:最后的完整目录应该是/usr/local/mysql)

二、调整目录权限

cd /usr/local
chown -R 当前登录mac的管理员用户名 mysql

这一步的目的,主要是保证/usr/local/mysql下可以写入数据

三、初始化数据库

cd /usr/local/mysql/bin
sudo ./mysqld --initialize --user=mysql
2018-12-01T14:42:12.002186Z 0 [System] [MY-013169] [Server] /usr/local/mysql/bin/mysqld (mysqld 8.0.13) initializing of server in progress as process 4229
2018-12-01T14:42:12.004783Z 0 [Warning] [MY-010159] [Server] Setting lower_case_table_names=2 because file system for /usr/local/mysql/data/ is case insensitive
2018-12-01T14:42:12.006285Z 0 [Warning] [MY-010122] [Server] One can only use the --user switch if running as root
2018-12-01T14:42:14.187443Z 5 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: iM46X&03qRc_
2018-12-01T14:42:15.427614Z 0 [System] [MY-013170] [Server] /usr/local/mysql/bin/mysqld (mysqld 8.0.13) initializing of server has completed

注意蓝色标出的部分,初始化过程中,会生成一个随机的root初始密码,记好这个,后面会用到。

如果没记下这个密码,导致后面无法登录,可以rm -rf /usr/local/mysql/data/* 把所有文件干掉,再来一把。

四、启动mysql
cd /usr/local/mysql/support-files

./mysql.server start (注:类似的status为查看状态,stop为停止服务)

Starting MySQL
. SUCCESS!

看到这个SUCCESS就表示启动成功了。

五、修改密码
cd /usr/local/mysql/bin
./mysqladmin -u root -p password

初始密码实在太难记了,可以用上面的命令先改一下 (注:密码要满足复杂性要求,比如Www.123.abc之类)

这一步做完后,应该就可以用

./mysql -u root -p

命令行终端登录了,不过8.0貌似安全策略做了调整,用navicat之类的工具连接,会出现:

Client does not support authentication protocol requested by server; consider upgrading MySQL client

之类的错误,解决方法:

use mysql
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';
FLUSH PRIVILEGES;

然后应该就可以了。

六、mysql 8新增的一些函数

6.1 over()开窗函数

over开窗函数,在oracle中早就有了,但是mysql直到8.0+才开始支持,参考文档见:https://dev.mysql.com/doc/refman/8.0/en/window-functions-usage.html,它的作用有点类似于将"聚合结果行转列", 具体参考下面的示例(来自官网)

如上图,这是一张销售记录表,上面记录了"某一年、某个国家、某种产品"的销售利润。如果我们要分析,每一行销售记录,在本年/本国/本类产品/甚至所有销售中的贡献度(即:所占百分比)。按传统思路,至少得先汇总出 "每年的总销售金额,每个国家的总销售金额,每类产品的总销售金额...",然后用本行的profit去除这些汇总值,才能计算出百分比。

有了over函数后,就可以很简单了:

SELECT
YEAR '年份' ,
country '国家' ,
product '产品' ,
profit '产品利润' ,
SUM(profit) OVER(PARTITION BY country , YEAR ,product) AS '年度-某国家-某产品-利润小计' ,
SUM(profit) OVER(PARTITION BY country , YEAR) AS '年度-某国-利润小计' ,
SUM(profit) OVER(PARTITION BY country) AS '某国-利润小计' ,
SUM(profit) OVER(PARTITION BY YEAR) AS '年度-利润小计' ,
SUM(profit) over() AS '利润合计'
FROM
sales
ORDER BY
YEAR ,
country ,
product ,
profit;

结果如下:

各种聚合结果,可以方便的展示在同一行,如果要输出百分比,直接拿"利润"这一栏,除以后面某一列汇总值即可。

6.2 row_number()函数

这个函数同样也是从oracle模仿过来的,用法如下:

select
row_number() over w as 'No.' ,
year ,
country ,
product ,
profit
from
sales
where
year = 2001 window w as(order by country)
order by country

输出:

详情可参考 https://dev.mysql.com/doc/refman/8.0/en/window-function-descriptions.html

mac上mysql8.0以tar.gz方式手动安装的更多相关文章

  1. 在Foreda上安装apache-tomcat-7.0.42.tar.gz

    开发环境JDK和Tomcat应该和部署环境一致,要不容易出现奇奇怪怪的问题.所以Aspire机器上的Tomcat要装一个新版本了. 装Tomcat基本等于一个解压和移动的过程,确实简单. 第一步:解压 ...

  2. apache-storm-1.0.2.tar.gz的集群搭建(3节点)(图文详解)(非HA和HA)

    不多说,直接上干货! Storm的版本选取 我这里,是选用apache-storm-1.0.2.tar.gz apache-storm-0.9.6.tar.gz的集群搭建(3节点)(图文详解) 为什么 ...

  3. Apache-kylin-2.0.0-bin-hbase1x.tar.gz的下载与安装(图文详解)

    首先,对于Apache Kylin的安装,我有话要说. 由于Apache Kylin本身只是一个Server,所以安装部署还是比较简单的.但是它的前提要求是Hadoop.Hive.HBase必须已经安 ...

  4. redis-5.0.5.tar.gz 安装

    参考5.0安装,地址:https://my.oschina.net/u/3367404/blog/2979102 前言 安装Redis需要知道自己需要哪个版本,有针对性的安装. 比如如果需要redis ...

  5. linux下安装nginx(nginx(nginx-1.8.0.tar.gz),openssl(openssl-fips-2.0.9.tar.gz) ,zlib(zlib-1.2.11.tar.gz),pcre(pcre-8.39.tar.gz))

    :要按顺序安装: 1:先检查是否安装 gcc ,没有先安装:通过yum install gcc-c++完成安 2:openssl : tar -zxf  openssl-fips-2.0.9.tar. ...

  6. Linux系统下安装配置JDK(rpm方式及tar.gz方式)

    以前都是在Windows环境进行开发的,最近因工作需要:学习在Linux系统下搭建开发环境,自此记录搭建过程,以方便查阅. 本文借鉴了 Angel挤一挤 .小五 两位的博客. 准备材料: JDK下载链 ...

  7. Linux下编译安装mysql-5.0.45.tar.gz

    安装环境:VMware9(桥接模式) + Linux bogon 2.6.32-642.3.1.el6.x86_64(查看linux版本信息:uname -a) 先给出MySQL For Linux ...

  8. 编译gd-2.0.35.tar.gz时报错:gd_png.c:16:53: error: png.h: No such file or directory

    编译gd-2.0.35.tar.gz时报错: gcc -DHAVE_CONFIG_H -I. -I. -I. -I/usr/local/freetype/include/freetype2 -I/us ...

  9. Centos6.5 安装 MariaDB-10.0.20-linux-x86_64.tar.gz

    下载mariadb :https://downloads.mariadb.org/  我选择mariadb-10.0.20-linux-x86_64.tar.gz这个版本 复制安装文件 /opt 目录 ...

随机推荐

  1. 第二种掌握的排序Q-Q

    #include<stdio.h> int main() {     int s[10000]={0};     int i=0,j=0,n=0,x=0;     scanf(" ...

  2. nginx 301重定向一种实现方法

    假设要使用的域名是b.com,以前的老域名是a.com,则以下设置让nginx把a.com的请求访问转发到b.com,并返回301给浏览器. server { listen 80; server_na ...

  3. Flask Web中用MySQL代替SQLite

    由于.sqlite文件操作的诸多不便,决定常识用MySQL代替书上的SQLite作为数据库. 1.在虚拟环境中安装mysql-Python具体步骤为: <1> 安装python-dev s ...

  4. Number Sequence kmp

    Problem Description Given two sequences of numbers : a[1], a[2], ...... , a[N], and b[1], b[2], .... ...

  5. day4 class work answer

    count=0 s = input("请输入内容:") # asd234fsdafa5456fsdaf1 while s: s=s.lstrip("abcdefghijk ...

  6. 总结几种清除浏览器的缓存,适用于明明已经修改bug,但是测试人员说问题还存在的情况下

    1.meta方法<METAHTTP-EQUIV="pragma"CONTENT="no-cache"><METAHTTP-EQUIV=&quo ...

  7. Java中菜单的实现以及画实线与画虚线之间的自由转化

    1.Java画线 1 import java.awt.Color; import java.awt.Container; import java.awt.Graphics; import java.a ...

  8. 牛客练习赛A 【BFS】

    <题目链接> 题目大意: 给出一张图,问你其中 ' # ' 加上那些不能够到达边界的 ' . ' 的点的个数,' # ' 会起阻挡作用. 解题分析: 本题很好做,无非就是将所有能够由边界上 ...

  9. Django 学习第十二天——Auth 系统

    一.Auth系统中的表: 从表的名称我们就能看出, auth_user,auth_group,auth_permission分别 存放了用户,用户组,权限的信息表. 另外三张表就是多对多的关系表 Us ...

  10. 双重保险——前端bootstrapValidator验证+后台MVC模型验证

    我们在前端使用BoostrapValidator插件验证最基本的格式要求问题,同时在后台中,使用MVC特有的模型验证来做双重保险.对于boostrapValidator我就不说了,具体请看<bo ...