项目1111

中文显示姓名列和手机号

SELECT contact_name AS '姓名', contact_phone AS '手机号' FROM 2_公司id;

使用explain测试给出的查询语句,显示走了索引查询

EXPLAIN SELECT * FROM `7_订单数量` WHERE `countid` LIKE 'e%';

统计用户订单信息,查询所有用户的下单数量,并进行倒序排序。使用聚合函数查询所有用户的订单数量,倒序拍列结果

SELECT   user_id ,sum(count_id) as '订单数量' from `4_订单id`
GROUP BY user_id
ORDER BY sum(count_id)  DESC;

 

显示用户信息,显示用户钱包信息,进行多表联合查询

SELECT 1_用户id.username, 1_用户id.name, 8_账户表.balance,1_用户id.password,1_用户id.email,1_用户id.gender
FROM 1_用户id
JOIN 8_账户表 ON 1_用户id.user_id = 8_账户表.user_id;

查看订单中下单最多的产品对应的类别正确使用聚合函数,正确使用子查询

SELECT product_name
FROM (SELECT product_name, COUNT(*) AS order_countFROM 5_详情idGROUP BY product_name
) AS subquery
ORDER BY order_count DESC
LIMIT 1;

查询下单总金额最多的用户,并查询用户的全部信息与当前钱包余额。正确使用聚合函数,正确使用子查询,正确进行多表联合查询

SELECT u.*, a.balance
FROM 1_用户id u
JOIN 8_账户表 a ON u.user_id = a.user_id
WHERE u.user_id = (SELECT user_idFROM (SELECT user_id, SUM(price * quantity) AS total_amountFROM 4_订单id oJOIN 5_详情id d ON o.order_id = d.order_idGROUP BY user_id) AS subqueryORDER BY total_amount DESCLIMIT 1
);

5、存储过程创建

1、添加一个用户下订单的存储过程,存储过程名称叫做【create_order_infos()】

2、要求传入创建订单所必须的参数内容,例如:用户编号、商品编号、购买数量等信息。

3、需要根据传入的信息插入【用户钱包交易日志表】、【订单表】、【订单详情表】信息,修改【用户钱包表】、【商品表】。

因为没有product表需先创建

CREATE TABLE `product` (`product_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '商品ID',`product_name` varchar(100) NOT NULL COMMENT '商品名称',`price` decimal(10,2) NOT NULL COMMENT '价格',`stock` int(11) NOT NULL COMMENT '库存',PRIMARY KEY (`product_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;INSERT INTO `product` VALUES (1, '手机', 5999.00, 10);
INSERT INTO `product` VALUES (2, '耳机', 299.00, 20);

然后完成存储过程

DELIMITER //
CREATE PROCEDURE create_order_infos(IN in_user_id INT,IN in_product_id INT,IN in_quantity INT
)
BEGINDECLARE product_price DECIMAL(10,2);DECLARE product_stock INT;DECLARE user_balance DECIMAL(10,2);DECLARE order_number VARCHAR(50);DECLARE order_id INT;DECLARE detail_id INT;-- 获取商品价格和库存SELECT price, stock INTO product_price, product_stockFROM productWHERE product_id = in_product_id;-- 检查库存是否足够IF product_stock < in_quantity THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '库存不足';END IF;-- 获取用户余额(这里假设用户只有一个账户)SELECT balance INTO user_balanceFROM 8_账户表WHERE user_id = in_user_id;-- 检查余额是否足够IF user_balance < (product_price * in_quantity) THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '余额不足';END IF;-- 生成订单编号(这里简化为拼接当前时间)SET order_number = CONCAT('ORD', DATE_FORMAT(NOW(), '%Y%m%d%H%i%s'));-- 插入订单表INSERT INTO 4_订单id (user_id, company_id, order_number, order_date, status_id, count_id)VALUES (in_user_id, 1, order_number, CURDATE(), 1, in_quantity); -- 假设默认公司ID为1,状态为待发货SET order_id = LAST_INSERT_ID(); -- 获取最新插入的订单ID-- 插入订单详情表INSERT INTO 5_详情id (order_id, product_name, quantity, price, category)SELECT order_id, product_name, in_quantity, product_price, '电子产品' -- 假设所有商品都是电子产品FROM productWHERE product_id = in_product_id;-- 更新商品库存UPDATE productSET stock = stock - in_quantityWHERE product_id = in_product_id;-- 更新用户余额(这里简化处理,不记录交易日志)UPDATE 8_账户表SET balance = balance - (product_price * in_quantity)WHERE user_id = in_user_id;-- 返回订单ID(这里通过SELECT返回,而不是OUT参数)SELECT order_id;
END //
DELIMITER ;

测试语句

-- 有一个用户id为5,二号商品,购买数量为1的商品
set @user_id=5;
set @product_id=2;
set @in_quantity=1;
set @order_id=NULL;
CALL create_order_infos(@user_id,@product_id,@in_quantity);
select @order_id;

-- 有一个用户id为1,一号商品,购买数量为1的商品
set @user_id=1;
set @product_id=1;
set @in_quantity=1;
set @order_id=NULL;
CALL create_order_infos(@user_id,@product_id,@in_quantity);
select @order_id;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/34938.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Prometheus中添加基本身份验证功能

在Prometheus中添加基本身份验证功能&#xff0c;可以按照以下步骤进行&#xff1a; 一、生成哈希密码 首先&#xff0c;需要安装bcrypt工具&#xff0c;用于生成哈希密码。这可以通过Python的bcrypt库来完成。如果未安装&#xff0c;可以使用pip进行安装。 创建一个Python脚…

Android性能优化——卡顿优化

文章目录 一、从XML到屏幕上的展示造成跳帧的因素有那些发现问题定位问题定位代码 一、从XML到屏幕上的展示 数据加载阶段 数据控制阶段 数据展示阶段 xml —> view onCreat —> 解析layout.xml resume —> view —> wms ViewRootImpl UI 绘制流程 &#xff1a;测…

计算机网络之数据通信原理

1.通信系统的基本组成 信源&#xff1a;信息的发出者&#xff1b; 信宿&#xff1a;信息的接收者&#xff1b; 载体&#xff1a;信息的传送通道&#xff1b; 变换器&#xff1a;将信息变换成载体上可传输的信号&#xff1b; 反变换器&#xff1a;将载体上传输的信号变换成信…

Java中网络安全的基础知识

Java中网络安全的基础知识 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在现代互联网应用中&#xff0c;网络安全是一个至关重要的话题。随着网络攻击和数据…

Java零基础-集合:TreeSet

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

SQL基础:掌握数据查询与操作的核心技能(四)

引言&#xff1a;数据操作的语言艺术 在前一章节《数据库与表的基本操作》中&#xff0c;我们深入了解了如何创建、管理数据库和表&#xff0c;构建了数据存储的基础框架。本章节&#xff0c;我们将深入探索SQL语言&#xff0c;它是数据库管理系统的通用语言&#xff0c;用于数…

SpringBoot集成Druid数据库连接池并配置可视化界面和监控慢SQL

pom.xml <!-- Druid 数据库连接池 --><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.23</version></dependency>application.yml spring:jackson:date-…

明星周边物品交易购物系统

摘 要 随着明星文化的兴起和粉丝经济的蓬勃发展&#xff0c;明星周边产品的市场需求日益增长。明星周边物品包括各种与明星相关的商品&#xff0c;如T恤、海报、手办、签名照等&#xff0c;它们成为粉丝们表达对明星喜爱和支持的方式之一。通过“星光璀璨”来形象化地表达明星…

Flask的 preprocess_request

理解 Flask 类似框架中的 preprocess_request 方法 在 Flask 类似的 web 框架中&#xff0c;preprocess_request 方法是一个关键组件。它在请求被分派之前调用&#xff0c;用于执行一些预处理操作。让我们一步一步来理解这个方法的工作原理。 1. 方法概述 首先&#xff0c;我…

【Android面试八股文】说一说Handler的sendMessage和postDelay的区别?

文章目录 一、`sendMessage` 方法1.1 主要用法1.2 适用场景二、`postDelayed` 方法2.1 主要用法2.2 适用场景三、 区别总结3.1 区别3.2 本质上有差别吗?四、实例对比4.1 使用`sendMessage`4.2 使用`postDelayed`五、结论Handler类在Android中用于消息传递和任务调度。 sendMe…

基于Java技术的在线学习平台系统

开头语&#xff1a;你好呀&#xff0c;我是计算机学姐码农小野&#xff01;如果有相关需求&#xff0c;可以私信联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;Java技术&#xff0c;基于SpringBoot框架 工具&#xff1a;Eclipse、Navicat、M…

n次方差公式推导

1. 推导 数列求和 S a 1 a 2 ⋯ a n , 公比为 q q S a 2 a 3 ⋯ a n 1 ( 1 − q ) S a 1 − a n 1 a 1 : 1 化简 ( 1 ) ( 3 ) S 1 q ⋯ q n − 1 ( 1 − q ) S 1 − q n ( 4 ) 代入 ( 5 ) ( 1 − q ) ( 1 q ⋯ q n − 1 ) 1 − q n q : b a 代入 ( 6 )…

Qt 学习(一) addressbook

Qt Demo: addressbook (1)创建项目&#xff1a;选择不创建界面&#xff0c;即UI&#xff0c;此时会自动生成的文件如图所示&#xff1a; QApplication&#xff1a; MainWindow 继承自 QMainWindow&#xff0c;根据需要设计的界面样式。 (2)确定MainWindow 的成员变量 首先&…

Jetpack架构组件_Navigaiton组件_1.Navigaiton切换Fragment

1.Navigation主要作用 方便管理Fragment &#xff08;1&#xff09;方便我们管理Fragment页面的切换 &#xff08;2&#xff09;可视化的页面导航图&#xff0c;便于理清页面间的关系。 &#xff08;3&#xff09;通过destination和action完成页面间的导航 &#xff08;4&a…

算尽天下财,铸就大明梦 —— 大明钱算子夏元吉的传奇一生

仕途生涯开始&#xff1a;洪武二十三年&#xff08;1390年&#xff09;&#xff0c;夏元吉因精通《诗经》&#xff0c;由湖广乡荐参加礼部组织的会试&#xff0c;虽未中举&#xff0c;但他并未气馁&#xff0c;反而更加努力地学习。洪武二十四年&#xff08;1391年&#xff09;…

通讯:单片机串口和电脑通讯

目录 1.串口输出数据到电脑 硬件部分 串口输出数据到电脑的软件软件部分&#xff1a; 相关问题&#xff1a; 2.单片机串口--485--485转USB--电脑 串口&#xff0c;芯片&#xff0c;转换器&#xff0c;设备之间的通讯的接线&#xff0c;都是要TX--RX, RX--TX 交叉连接。 单…

充电桩现场安装施工流程

摘要&#xff1a;在化石能源日益紧缩的今天&#xff0c;新能源车辆逐渐走进了千家万户&#xff0c;与传统化石能源车辆相比&#xff0c;以电驱动的新能源车辆能源利用率高&#xff0c;缩短了能源传递过程&#xff0c;实现了能源有效利用。根据能量守恒定律可知&#xff0c;任何…

V-Series Avalon-MM DMA Interface for PCIE IP核

目录 1. IP概述 2. Avalon-MM DMA Ports 3. 参数设置 3.1 系统设置 3.2 基址寄存器 (BAR) 设置 3.3 设备识别寄存器 3.4 PCI Express和PCI功能参数 3.4.1 Device Capabilities 3.4.2 Error Reporting 3.4.3 Link Capabilities 3.4.4 MSI and MSI-X Capabilities …

机器发货到菲律宾的完整流程 广东智慧物流

机器发货到菲律宾的完整流程 广东智慧物流 &#x1f31f;【机器发货到菲律宾完全攻略】&#x1f31f; 机器发货到菲律宾的完整流程 广东智慧物流 为你整理了一份超详细的机器发货到菲律宾的攻略&#xff01;海运14天轻松到达&#xff0c;让你无后顾之忧&#xff01;&#x1f…

知识平台管理系统设计

知识平台管理系统设计是一个综合性的过程&#xff0c;旨在为企业或组织提供一个高效、便捷的知识管理解决方案。以下是知识平台管理系统设计的详细阐述&#xff1a; 一、设计目标和原则 1、设计目标&#xff1a;设计一款功能强大、易于使用、支持多种知识形式分类和搜索的知识管…