先来简单了解一下MySQL数据库有意思的简介

MySQL这个名字,起源不是很明确。一个比较有影响的说法是,基本指南和大量的库和工具带有前缀“my”已经有10年以上,
而且不管怎样,MySQL AB创始人之一的Monty Widenius的女儿也叫My。这两个到底是哪一个给出了MySQL这个名字至今依然是个迷,包括开发者在内也不知道。
MySQL的海豚标志的名字叫“sakila”,它是由MySQL AB的创始人从用户在“海豚命名”的竞赛中建议的大量的名字表中选出的。
获胜的名字是由来自非洲斯威士兰的开源软件开发者Ambrose Twebaze提供。
根据Ambrose所说,Sakila来自一种叫SiSwati的斯威士兰方言,也是在Ambrose的家乡乌干达附近的坦桑尼亚的Arusha的一个小镇的名字。
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的 临时表,变量,行转列,预处理的一些相关技术的使用!的更多相关文章

  1. MySQL存储过程的动态行转列

    MySQL存储过程中使用动态行转列 最近做项目关于数据报表处理,然而数据库存储格式和报表展现形式不同,需要进行一下行转列的操作,在做上一个项目的时候也看了一下,但是后来换了读取方式,也就没深入研究这个 ...

  2. MYSQL开发技巧之行转列和列转行

    行转列--两种方法第一种方法:行转列我们通常是使用交叉连接和子查询的方式做到,比如下面的例子,查询每个name的对应id的和mysql> select * from user; +----+-- ...

  3. Mysql或者Hive数据行变成列

    对于mysql /  hive 再进行统计的时候假设须要行变成列,能够使用函数 CASE 字段a WHEN 值b THEN c [WHEN d THEN e]* [ELSE f] END 当字段a=值 ...

  4. 【mysql经典题目】行转列

    参考:http://www.cnblogs.com/h07061108/p/mysql_questions.html#3806338 实现如下效果 CREATE TABLE IF NOT EXISTS ...

  5. mysql sql语句:行转列问题

    存在表score,记录学生的考试成绩,如下图所示: 现要求以 学生姓名,语文,数学,英语 这种格式显示学生成绩,如下图所示 具体步骤如下: 1.首先,使用case when函数输出单个课程的成绩 ca ...

  6. Oracle学习笔记:一个简单的行转列例子

    一个简单的行列转换例子,原始数据. create table temp_cwh_student ( name ), subject ), score ) ) select * from temp_cw ...

  7. MySQL 行转列 -》动态行转列 -》动态行转列带计算

    Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...

  8. 黑马MySQL数据库学习day04 MySQL变量 存储过程 用户和授权管理

    /* MySQL中的变量局部变量,用户变量,会话变量和全局变量. 用户变量不用定义,直接使用. 1.用户变量赋值 set @xxx = 值; 2.查询 select @xxx; 语法帮助: 过程保存在 ...

  9. 数据库学习之MySQL基础

    数据库基础 一.数据库简介 数据库:存放数据的仓库 sql及其规范 sql是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集,是一种功能 ...

随机推荐

  1. 【问题记录】ajax dataType属性

    最近整理代码,发现一些ajax dataType 属性值设置的问题.下面直接上代码说明下 前台ajax请求 $.ajax({ type: "get", dataType: &quo ...

  2. Canal工作原理

    摘自:http://www.importnew.com/25189.html 背景 mysql主备复制实现: 从上层来看,复制分成三步: master将改变记录到二进制日志(binary log)中( ...

  3. 【AHOI2009】同类分布 题解(数位DP)

    题目大意:求$[l,r]$中各位数之和能被该数整除的数的个数.$0\leq l\leq r\leq 10^{18}$. ------------------------ 显然数位DP. 搜索时记录$p ...

  4. SqlServer 多表连接、聚合函数、模糊查询、分组查询应用总结(回归基础)

    --exists 结合 if else 以及 where 条件来使用判断是否有数据满足条件 select * from Class where Name like '%[1-3]班' if (not ...

  5. 电力规约DL/T 654 2007多功能电表通信协议 调试工具

    DL/T 654 2007多功能电表通信协议 调试工具 最近调试DL/T654 2007电力规约,在网上找到一个比较好用的工具,分享给大家,希望对大家有帮助. CSDN需要积分,我传百度网盘了, 内含 ...

  6. hashCode竟然不是根据对象内存地址生成的?还对内存泄漏与偏向锁有影响?

    起因 起因是群里的一位童鞋突然问了这么问题: 如果重写 equals 不重写 hashcode 会有什么影响? 这个问题从上午10:45 开始陆续讨论,到下午15:39 接近尾声 (忽略这形同虚设的马 ...

  7. 18、Memento 备忘录模式

    例如:用于记录快照(顺势状态).存盘 1.Memento Memento设计模式是一种软件设计模式,用于将对象回滚到其先前状态.它是行为设计模式的一部分,与算法和对象之间的职责分配有关. 行为模式描述 ...

  8. 商品描述(动画)--- jQuery

    本文章实现是基于jQuery展示商品描述的一个功能 (1)鼠标移入显示描述内容,鼠标移开内容隐藏.先来看看一个先后效果. (2)jQuery所以的文件可以自行下载,也可以在我主页找到文件,右键文件名复 ...

  9. 【Docker】 Error running deviceCreate (CreateSnapDeviceRaw)

    问题详细信息: [root@passport docker]# docker-compose -f docker-compose.yml up -ddocker_db_1_1651de706222 i ...

  10. 2020-07-10:sql如何调优?

    福哥答案2020-07-10:此答案来自群成员: SQL提高查询效率的几点建议 1.如果要用子查询,那就用EXISTS替代IN.用NOT EXISTS替代NOT IN.因为EXISTS引入的子查询只是 ...