热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

本周学习总结:MySQL函数的应用与Python书籍外借经历

本周,我深入研究了ECharts插件的使用方法,整体感觉插件操作较为简便,但后台算法较为复杂。此外,我还学习了MySQL函数的新应用,进一步提升了数据库操作的灵活性。同时,分享了自己在Python书籍外借过程中的体验,总结了一些实用的借阅技巧和心得。

这个礼拜,研究了echarts 插件的使用。总的来说,插件不难受,但是后台的算法很复杂。

 然后学习了一种全新的sql语句的应用(自己孤陋寡闻)

比如说我想查询某一时间段内的东西

select * from table where YEAR(time)=2017 and MONTH(time)=10 #一条简单的查询,取得符合date类型其中时间为2017 ,月份为10月的数据,其中2017 / 10 两个变量为数字类型

通过简单的函数YEAR和MONTH就能提取出时间类型(time)的年和月,估计天,小时,分,秒也能!这里没细研究。

select ifnull(num,0) from table #一个简单的查询出来的null值默认为0,还记得oracle数据库中为nvl()。

seelct sex
(
case sex when 1 then "男" #case when then 语句,把符合你条件的语句,以你想要的格式显示出来,比之前的ifnull更加强大 when 2 then "女"else "人妖"end
)
from table

最近还尝试写了一下,mysql的触发器

CREATE TRIGGER tr_test #字面上可能就能理解,在test1表执行更新之后,对test2表进行操作如sql语句。
AFTER
UPDATE ON test1        #其中 TRIGGER为触发器关键词。还有更新前/后,插入前/后,删除前/后。大部分只是更改其关键词 after/before insert/update/delete
FOR EACH ROW #在说一个自己经历的小坑,对,触发器只能对另一张表进行操作。也就是说begin/end中的sql语句只能对另一张表进行操作。可能是防止无线循环
BEGIN                  #这里可能看到old.name 函数。显然就有new,old是指更新数据后,之前的数据,new就是更新的数据。这里比较抽象,各位可以慢慢尝试就懂了           
uppdate test2
SET name=new.name WHERE name=old.name;
END;

还有不怎么常用,但是能节省大量java段代码的存储过程,就是把java段的运算,写在mysql数据库段。

DELIMITER ;;
CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(IN type int)
BEGIN
if type=1 then #IN type int 代表传入一个参数tyep类型为int.set c=1; #这个存储过程自己老是写不好,不是逻辑不会,而是代码的格式老是报错。至今也是迷迷糊糊,半错半对的就蒙过去了
else if type=2 then #其中参数问题,可以声明返回值,OUT c int 声明返回一个c变量,类型为int set c=2;
else set c=3;
end if;
select c;
end
;;
DELIMITER ;

下面是调用实例

set @type=3; #先声明参数数值为3,然后call存储过程,结果为3;
call test(
@type); #这是因为存储过程里面我自写了一个查询c的sql在里面,所以运行时会自己查询

如果我上面的存储过程没有select c 该怎么去过去c的值呢?

只需要把参数添加一个,OUT c int

调用实例

set @type=3;
call test(
@type,@c); 因为自己知道@c是返回值,所以运行后,@c是已经有值的,这里直接查询就行了
select @c;

 

转:https://www.cnblogs.com/chenchengyi/p/7751634.html



推荐阅读
  • 本文将详细介绍如何在SSM框架中无缝集成ShardingSphere 4.10,以实现高效的数据分片和读写分离。通过实例演示和代码解析,帮助开发者快速掌握这一复杂但实用的技术。文章从基础概念入手,逐步深入到具体配置和应用实践,旨在为读者提供一个全面、易懂的整合指南。 ... [详细]
  • 本文深入探讨了 C# 中 `SqlCommand` 和 `SqlDataAdapter` 的核心差异及其应用场景。`SqlCommand` 主要用于执行单一的 SQL 命令,并通过 `DataReader` 获取结果,具有较高的执行效率,但灵活性较低。相比之下,`SqlDataAdapter` 则适用于复杂的数据操作,通过 `DataSet` 提供了更多的数据处理功能,如数据填充、更新和批量操作,更适合需要频繁数据交互的场景。 ... [详细]
  • BZOJ4240 Gym 102082G:贪心算法与树状数组的综合应用
    BZOJ4240 Gym 102082G 题目 "有趣的家庭菜园" 结合了贪心算法和树状数组的应用,旨在解决在有限时间和内存限制下高效处理复杂数据结构的问题。通过巧妙地运用贪心策略和树状数组,该题目能够在 10 秒的时间限制和 256MB 的内存限制内,有效处理大量输入数据,实现高性能的解决方案。提交次数为 756 次,成功解决次数为 349 次,体现了该题目的挑战性和实际应用价值。 ... [详细]
  • 在Ubuntu系统中,由于预装了MySQL,因此无需额外安装。通过命令行登录MySQL时,可使用 `mysql -u root -p` 命令,并按提示输入密码。常见问题包括:1. 错误 1045 (28000):访问被拒绝,这通常是由于用户名或密码错误导致。为确保顺利连接,建议检查MySQL服务是否已启动,并确认用户名和密码的正确性。此外,还可以通过配置文件调整权限设置,以增强安全性。 ... [详细]
  • PHP连接MySQL的三种方法及预处理语句防止SQL注入的技术详解
    PHP连接MySQL的三种方法及预处理语句防止SQL注入的技术详解 ... [详细]
  • 在 Oracle 数据库中,`NULLS FIRST` 和 `NULLS LAST` 是 `ORDER BY` 子句中用于控制空值排序位置的关键字。当使用 `NULLS FIRST` 时,无论排序顺序是升序 (`ASC`) 还是降序 (`DESC`),包含空值的记录都会被排列在结果集的最前面。相反,`NULLS LAST` 则确保空值记录被放置在结果集的最后。这些关键字提供了灵活的排序选项,特别是在处理包含大量空值的数据集时,能够更好地满足不同的业务需求。 ... [详细]
  • SQL字符串操作:深入解析 instr、substr 和 like 函数的应用与区别
    在进行SQL字符串操作时,经常会用到 `instr`、`substr` 和 `like` 函数。本文详细解析了这些函数的应用场景和区别。特别是 `like` 函数在处理文件路径匹配时可能会遇到的问题,如通配符 `_` 和 `%` 的使用。其中,`%` 可以匹配零个或多个任意字符,而 `_` 则匹配任意单个字符。通过实例和文档解析,帮助读者更好地理解和应用这些函数。 ... [详细]
  • Windows环境下详细教程:如何搭建Git服务
    Windows环境下详细教程:如何搭建Git服务 ... [详细]
  • iOS开发中MVC架构模式的深入解析(第一部分)
    在iOS开发中,MVC架构模式是常用的设计模式之一。本文将深入解析MVC架构的第一部分,重点介绍View组件。View组件继承自UIView,主要负责内容的展示(如UILabel等视图类)和用户输入的处理(如UIButton等控件类)。通过详细的代码示例和实际应用,帮助开发者更好地理解和掌握View在MVC架构中的作用和实现方式。 ... [详细]
  • 本文提供了在Windows系统上部署和启动MySQL免安装版本的详细步骤。首先,从MySQL官方网站下载社区版免安装包(https://dev.mysql.com/downloads/mysql/8.0.html),将其解压至指定目录,例如D:\tools\mysql。接着,配置系统环境变量,确保MySQL命令行工具可以在任意路径下使用。此外,还需创建并配置my.ini文件以设置MySQL的基本参数,确保数据库服务能够顺利启动和运行。 ... [详细]
  • 题目链接:http://poj.org/problem?id=3083。题目描述:给定一个迷宫,其中 'S' 表示起点,'E' 表示终点,'#' 表示墙壁,'.' 表示可通行的道路。起点和终点均位于迷宫的边界上,并且保证存在唯一路径。任务是求从起点 'S' 到终点 'E' 的最短路径步数,且优先考虑向左转弯。通过深度优先搜索(DFS)和广度优先搜索(BFS)算法进行路径探索,分析两种方法的优劣及适用场景。 ... [详细]
  • Java 零基础入门:SQL Server 学习笔记(第21篇)
    Java 零基础入门:SQL Server 学习笔记(第21篇) ... [详细]
  • 本文提供了 RabbitMQ 3.7 的快速上手指南,详细介绍了环境搭建、生产者和消费者的配置与使用。通过官方教程的指引,读者可以轻松完成初步测试和实践,快速掌握 RabbitMQ 的核心功能和基本操作。 ... [详细]
  • 本文将深入探讨Java编程语言中顶级类`Object`的源码实现,旨在为Java新手提供进阶指导。`Object`类是所有Java类的基类,了解其内部机制对于提升编程技能至关重要。文章首先介绍了API文档的使用方法,这对于有开发经验的Java程序员来说是不可或缺的工具。通过详细解析`Object`类的关键方法和属性,读者可以更好地理解Java的核心原理和设计思想。此外,文章还提供了实际代码示例,帮助读者在实践中掌握这些知识。 ... [详细]
  • Java 中使用 OptionalDouble 的 (Double) 方法示例解析 ... [详细]
author-avatar
荣哥918
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有