服务器上数据库的创建

破案了!🎯 真正的死因终于找到了:

Caused by: com.mysql.cj.exceptions.CJException: Unknown database 'newbee_mall_db'

这说明你的 Java 程序成功连上了 Docker 里的 MySQL,但是 MySQL 里面根本没有 newbee_mall_db 这个数据库! 这是一个空库。

🛠️ 解决方法(只需 3 步):

第一步:进入 Docker 容器并登录数据库
复制代码
docker exec -it mysql-server bash
mysql -u root -p123456
第二步:创建数据库

mysql> 提示符下执行以下 SQL 语句建库:

复制代码
CREATE DATABASE IF NOT EXISTS newbee_mall_db CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

(注:如果你的配置文件里写的不是 newbee_mall_db,请换成你配置文件中实际写的名字)

第三步:导入初始化数据(非常关键!)

光建一个空库是不行的,商城还需要表结构和初始数据。新蜂商城项目源码中通常自带了一个 .sql 文件(一般在项目的 sql/ 目录下,或者叫 newbee_mall_schema.sql)。

你需要把这个 SQL 文件上传到服务器上,然后在这个 mysql> 界面下导入:

复制代码
use newbee_mall_db;
source /你上传的SQL文件的绝对路径/newbee_mall_schema.sql;

如果嫌麻烦,你也可以先退出 MySQL(输入 exit),回到宿主机命令行直接用一条命令导入:

复制代码
# 假设你把 sql 文件放在了 /etc/nginx/java/ 目录下
docker cp /etc/nginx/java/newbee_mall_schema.sql mysql-server:/tmp/newbee_mall_schema.sql
docker exec -it mysql-server mysql -u root -p123456 newbee_mall_db < /tmp/newbee_mall_schema.sql

完成这三步后,不需要重启 Java 项目,直接刷新浏览器页面,你的新蜂商城就能正常显示了!快去试试吧!

相关推荐
唐青枫3 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满8783 天前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H4 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶5 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵5 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking5 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
李白客7 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6009 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL9 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql