mysql多字段修改update_docker安装mysql容器进行部署

233c245bac0edcb524f4897e70d242e0.png

docker安装mysql,远程访问

//搜索mysql
docker search mysql
//选定版本,抓取镜像
docker pull mysql:8.0
//创建同步mysql的文件夹
mkdir -p /data/mysql01
//创建容器
docker run --name mysql01  -p 3307:3306 -v /data/mysql01:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=zan123456 -d mysql:8.0 


--restart 标志会检查容器的退出代码,并据此来决定是否要重启容器,默认是不会重启。
--restart的参数说明
always:无论容器的退出代码是什么,Docker都会自动重启该容器。
on-failure:只有当容器的退出代码为非0值的时候才会自动重启。另外,该参数还接受一个可选的重启次数参数,`--restart=on-fialure:5`表示当容器退出代码为非0时,Docker会尝试自动重启该容器,最多5次。

-v 容器内的 /var/lib/mysql 在宿主机上 /data/mysql01 做映射  
-e MYSQL_ROOT_PASSWORD 初始密码
-p 将宿主机3306的端口映射到容器3306端口

error:如果启动失败,查看日志docker logs mysql01提示

chown: cannot read directory '/var/lib/mysql/': Permission denied

容器中没有执行权限 //挂载外部数据卷时,无法启动容器, 报 chown: cannot read directory '/var/lib/mysql/': Permission denied 由$ docker logs [name] 查看得知 该原因为centOs7默认开启selinux安全模块,需要临时关闭该安全模块,或者添加目录到白名单 临时关闭selinux:su -c "setenforce 0" 重新开启selinux:su -c "setenforce 1" 添加selinux规则,将要挂载的目录添加到白名单: 示例:chcon -Rt svirt_sandbox_file_t /data/mysql01(我启动挂载的路径)

error:用navicat连接如果报错

d2a08fdd82d1d64667df3b37f7b227d3.png
报错是因为加密算法变了

我们在docker里面改变加密算法

mysql> grant all PRIVILEGES on *.* to root@'%' WITH GRANT OPTION;
Query OK, 0 rows affected (0.01 sec)
 
mysql> ALTER user 'root'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
Query OK, 0 rows affected (0.11 sec)
 
mysql> ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
Query OK, 0 rows affected (0.11 sec)
 
mysql>  FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)

算法换成mysql_native_password即可

create数据库,并且创建表单引入mysql用以开发扫码点餐

封装为后缀sql的文件,在navicat导入即可

drop database if exists shop;
create database shop default character set utf8 collate utf8_general_ci;
use shop;

#类目
create table `product_category`
(
  `category_id`   int         not null auto_increment,
  `category_name` varchar(64) not null comment '类目名字',
  `category_type` int         not null comment '类目编号',
  `create_time`   timestamp   not null default current_timestamp comment '创建时间',
  `update_time`   timestamp   not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`category_id`)
) comment '类目表';

#菜单信息
create table `product_info`
(
  `product_id`          varchar(32)   not null,
  `product_name`        varchar(64)   not null comment '商品名称',
  `product_price`       decimal(8, 2) not null comment '单价',
  `product_stock`       int           not null comment '库存',
  `product_description` varchar(64) comment '描述',
  `product_icon`        varchar(512) comment '小图',
  `product_status`      tinyint(3)             DEFAULT '0' COMMENT '商品状态,0正常1下架',
  `category_type`       int           not null comment '类目编号',
  `create_time`         timestamp     not null default current_timestamp comment '创建时间',
  `update_time`         timestamp     not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`product_id`)
) comment '商品表';

#订单详情
create table `order_master`
(
  `order_id`      varchar(32)   not null,
  `buyer_name`    varchar(32)   not null comment '买家名字',
  `buyer_phone`   varchar(32)   not null comment '买家电话',
  `buyer_table`    varchar(128)  not null comment '买家桌号',
  `buyer_openid`  varchar(64)   not null comment '买家微信openid',
  `order_amount`  decimal(8, 2) not null comment '订单总金额',
  `order_status`  tinyint(3)    not null default '0' comment '订单状态, 默认为新下单',
  `pay_status`    tinyint(3)    not null default '0' comment '支付状态, 默认未支付',
  `create_time`   timestamp     not null default current_timestamp comment '创建时间',
  `update_time`   timestamp     not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`order_id`),
  key `idx_buyer_openid` (`buyer_openid`)
) comment '订单表';

#订单商品信息
create table `order_detail`
(
  `detail_id`        varchar(32)   not null,
  `order_id`         varchar(32)   not null,
  `product_id`       varchar(32)   not null,
  `product_name`     varchar(64)   not null comment '商品名称',
  `product_price`    decimal(8, 2) not null comment '当前价格,单位分',
  `product_quantity` int           not null comment '数量',
  `product_icon`     varchar(512) comment '小图',
  `create_time`      timestamp     not null default current_timestamp comment '创建时间',
  `update_time`      timestamp     not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`detail_id`),
  key `idx_order_id` (`order_id`)
) comment '订单商品';


#卖家信息
create table `seller_info`
(
  `seller_id`   int         not null auto_increment,
  `username`    varchar(32) not null,
  `password`    varchar(32) not null,
  `phone`       varchar(64) not null comment '用户手机号',
  `create_time` timestamp   not null default current_timestamp comment '创建时间',
  `update_time` timestamp   not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`seller_id`)
) comment '卖家信息表';
INSERT INTO seller_info VALUES (1, 'calvin', '289016698', '289016698',now(),now());

#用户信息
create table `user`
(
  `id`          INT         not null auto_increment,
  `username`    varchar(32) not null,
  `phone`       varchar(32) not null,
  `openid`      varchar(64) not null comment '微信openid',
  `table_number`     varchar(64) comment '桌号',
  `people_number`      varchar(64) comment '就餐人数',
  `create_time` timestamp   not null default current_timestamp comment '创建时间',
  `update_time` timestamp   not null default current_timestamp on update current_timestamp comment '修改时间',
  primary key (`id`)
) comment '用户信息表';

#桌位信息
create table `desk_info`
(
  `desk_id` INT   not null auto_increment,
  `desk_number` varchar(32) not null,
  `desk_type`  varchar(32) not null,
  `desk_status` tinyint(3)    not null default '0' comment '桌面状态, 默认为空置',
  `create_time` timestamp   not null default current_timestamp comment '创建时间',
  `update_time` timestamp   not null default current_timestamp on update current_timestamp comment '修改时间',
   primary key(`desk_id`)
) comment '桌位信息表';

create table `code_picture`
(
  `pic_id`      INT          not null auto_increment,
  `pic_url`     varchar(512) not null,
  `desk_number` varchar(64)  not null,
  `pic_create`  timestamp    not null default current_timestamp comment '创建时间',
  primary key (`pic_id`)
) comment '二维码图片';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值