今天来学习一下MySQl的 临时表,变量,行转列,预处理的一些相关技术的使用!
先来简单了解一下MySQL数据库有意思的简介
言归正传:今天来学习使用MySQl的 临时表,变量,行转列,预处理的一些入门使用相关话题!
个人之前一直使用比较多的数据库就是Sqlserver,Sqlserver的强大,和存储过程的牛13的地方这里不多说了,
在在主流的关系型数据库中,Mysql,Sqlserver,Oracle等,作者都有使用,相比还是微软的Sqlserver是最人性化的,数据库自带的工具也是最好用的
什么,执行计划,作业任务,表分区,主从复制,读写分离,存储过程,自定义类型,表函数,标量函数等等,都是比较人性化的使用!
新的公司使用的是Mysql关系型数据库,curd其实大都数的sql语法类似Sqlserver,
但是个人还是觉得MySQl比较弱,功能和使用体验上完全就不是一个等级的,
这里没有其他的故意贬低MySQl的意思,也不展开讨论这个话题,
存在即有其中的道理,毕竟MySql也有自身的优点,例如:体积小巧,开源免费等!
1:临时表 使用案例
语法案例如下:
DROP TEMPORARY TABLE if EXISTS p_table; //如果存在就先删除
CREATE TEMPORARY TABLE p_table // 创建临时表根据下面的查询结果来处理
SELECT S.id,S.score
FROM studentscore S
WHERE S.id>1;
SELECT id, score FROM p_table;

2:mysql语句自定义变量 使用案例
SET @id=1;// 带上标量,后面需要;分号结尾
DROP TEMPORARY TABLE if EXISTS p_table;
CREATE TEMPORARY TABLE p_table
SELECT S.id,S.score
FROM studentscore S
WHERE S.id>@id;
SELECT id, score FROM p_table;

3:mysql的行转列 使用案例
在Mysql中行转列通常有 case when,和 if(a='' b,c)再结合 max,sum,avg 这样的函数来处理
3.1:先创建表studentScore已经插入一些测试的数据
DROP TABLE IF EXISTS studentScore;
CREATE TABLE studentScore(
id INT(11) NOT NULL auto_increment,
userid VARCHAR(20) NOT NULL COMMENT '用户id',
subject VARCHAR(20) COMMENT '科目',
score DOUBLE COMMENT '成绩',
PRIMARY KEY(id)
)ENGINE = INNODB DEFAULT CHARSET = utf8;
INSERT INTO studentScore(userid,subject,score) VALUES ('111','语文',98);
INSERT INTO studentScore(userid,subject,score) VALUES ('111','数学',88);
INSERT INTO studentScore(userid,subject,score) VALUES ('111','英语',58);
INSERT INTO studentScore(userid,subject,score) VALUES ('222','语文',69);
INSERT INTO studentScore(userid,subject,score) VALUES ('222','数学',88);
INSERT INTO studentScore(userid,subject,score) VALUES ('222','英语',80);
INSERT INTO studentScore(userid,subject,score) VALUES ('333','语文',90);
INSERT INTO studentScore(userid,subject,score) VALUES ('333','数学',75);
INSERT INTO studentScore(userid,subject,score) VALUES ('333','英语',82);
INSERT INTO studentScore(userid,subject,score) VALUES ('333','政治',91);
SELECT* FROM studentScore;

3.1:行转列 使用案例,使用max,正常的情况下一个用户与一条数据,就可以使用sum(),max取其中最大的那条

3.2:行转列 ,if() 使用案例

3.3:使用SUM(IF()) 生成列 + UNION 生成汇总行,并利用 IFNULL将汇总行标题显示为 Total

4:Mysql的预处理语句的使用案例:

5:最后,看到MySQl也可以有上面的这些功能,是不是一下子对MySQl产生了好感,
原来MySQl也是如此可爱啊,嘻嘻!!!
今天来学习一下MySQl的 临时表,变量,行转列,预处理的一些相关技术的使用!的更多相关文章
- MySQL存储过程的动态行转列
MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...
- MYSQL开发技巧之行转列和列转行
行转列--两种方法第一种方法:行转列我们通常是使用交叉连接和子查询的方式做到,比如下面的例子,查询每个name的对应id的和mysql> select * from user; +----+-- ...
- Mysql或者Hive数据行变成列
对于mysql / hive 再进行统计的时候假设须要行变成列,能够使用函数 CASE 字段a WHEN 值b THEN c [WHEN d THEN e]* [ELSE f] END 当字段a=值 ...
- 【mysql经典题目】行转列
参考:http://www.cnblogs.com/h07061108/p/mysql_questions.html#3806338 实现如下效果 CREATE TABLE IF NOT EXISTS ...
- mysql sql语句:行转列问题
存在表score,记录学生的考试成绩,如下图所示: 现要求以 学生姓名,语文,数学,英语 这种格式显示学生成绩,如下图所示 具体步骤如下: 1.首先,使用case when函数输出单个课程的成绩 ca ...
- Oracle学习笔记:一个简单的行转列例子
一个简单的行列转换例子,原始数据. create table temp_cwh_student ( name ), subject ), score ) ) select * from temp_cw ...
- MySQL 行转列 -》动态行转列 -》动态行转列带计算
Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...
- 黑马MySQL数据库学习day04 MySQL变量 存储过程 用户和授权管理
/* MySQL中的变量局部变量,用户变量,会话变量和全局变量. 用户变量不用定义,直接使用. 1.用户变量赋值 set @xxx = 值; 2.查询 select @xxx; 语法帮助: 过程保存在 ...
- 数据库学习之MySQL基础
数据库基础 一.数据库简介 数据库:存放数据的仓库 sql及其规范 sql是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集,是一种功能 ...
随机推荐
- 【小白学AI】线性回归与逻辑回归(似然参数估计)
文章转自[机器学习炼丹术] 线性回归解决的是回归问题,逻辑回归相当于是线性回归的基础上,来解决分类问题. 1 公式 线性回归(Linear Regression)是什么相比不用多说了.格式是这个样子的 ...
- .Net Core下基于Emit的打造AOP
之前的基于DispatchProxy的AOP组件,实现了属性注入,但是这个依旧有很多限制 比如不支持构造器注入,继承DispatchProxy的子类必须是公开类 个人有点代码洁癖,不喜欢这种不能控制的 ...
- 重学c#系列——异常续[异常注意事项](七)
前言 对上节异常的补充,也可以说是异常使用的注意事项. 正文 减少try catch的使用 前面提及到,如果一个方法没有实现该方法的效果,那么就应该抛出异常. 如果有约定那么可以按照约定,如果约定有歧 ...
- kubernetes ingress 重定向地址错误
环境: 有两个 kubernetes 集群: 一个版本为1.11,后面使用A集群代替,ingress 镜像版本为 0.19(quay.io/kubernetes-ingress-controller/ ...
- 构建一个拥有sshd服务的docker镜像
不直接描述结果,通过一个过程探究如何写一个 Dockerfile 一.环境 虚拟机CentOS7.4,Docker1.13.1 二.尝试步骤 1.下载基础镜像 docker pull alpine:3 ...
- python8.1多线程
import threadingimport time def run1 (name,sex): print(name,sex,"执行线程1") time.sleep(3)def ...
- SonarQube 扫描 Java 代码
SonarQube 扫描 Java 代码 环境 需要提前安装好 SonarQube7.9,安装步骤见 Docker 安装 SonarQube 步骤 填写项目名 my_project 填写token名 ...
- Take C# 8.0 for a spin
本文章为机器翻译.https://blogs.msdn.microsoft.com/dotnet/2018/12/05/take-c-8-0-for-a-spin/ 以C # 8兜风 我们昨天宣布Vi ...
- LeetCode 309 Best Time to Buy and Sell Stock with Cooldown 解决方案
题目描述 给定一个整数数组,其中第 i 个元素代表了第 i 天的股票价格 . 设计一个算法计算出最大利润.在满足以下约束条件下,你可以尽可能地完成更多的交易(多次买卖一支股票): 你不能同时参与多笔 ...
- NodeJs+Express+SqlServer简易后台API服务搭建
首先安装nodejs 第一步 创建node项目配置package.json如下 express 使用方法可参考http://www.runoob.com/nodejs/nodejs-express-f ...