首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【SQL】小心环中声明变量——浅析SQL变量作用域

事实上这个语句会报2次“违反了PRIMARY KEY约束…”,原因是@t这个表变量,并不是每一圈都重新声明一个新的,而是声明1次后就一直沿用,由于该表具有主键约束,所以之后的两圈插入的时候,由于已经存在相同主键...之后的圈则进入该分支 SET @s += 's' PRINT @s SET @i += 1 END --执行结果: s ss sss 所以到这里能得出一个结论: 循环中变量只会声明一次...原因就在于声明语句比较特殊,它并不依赖位置,系统“见到”就算数,所以不管变量多深的语句块中声明,它在本批接下来的语句中都是有效的。...印象中某种SQL的写法是声明一个区,逻辑一个区,既然你t-sql的声明具有“提升”这种特点,我认为做成那种比较好,而不是混在逻辑语句中搞特殊。...回到开头的问题,现在我们清楚,虽然变量环中声明,但它并不会被多次执行,甚至不是第1圈的时候执行,而是某个时机由系统将所有声明统一执行,大概类似C#的静态字段,不管定义在哪里,CLR会确保使用该类前完成初始化

1.7K20

Java变量声明循环体内还是循环体外你用哪一个?

引言 最近刷知乎的时候看到一个比较有意思的问题,变量声明循环体内还是循环体外?这个问题有人认为应该定义循环体外,不应该定义循环体内。...很多java代码优化建议都有这么一条建议:循环内不要不断创建对象引用 例如: for (int i = 1; i <= count; i++){ Object obj = new Object(...这条建议应该也出现过很多公司的代码规范上了吧。下面我们就来分析下变量声明循环体内和变量声明循环体外的情况。...slot outsideLoop中,变量o和b分别占用了不同的slot,intsideLoop中,变量o和b复用一个slot。...从“「局部变量作用域最小化」”原则上来说,变量声明循环体内更合适一点,这样代码的阅读性更好。 结束 由于自己才疏学浅,难免会有纰漏,假如你发现了错误的地方,还望留言给我指出来,我会对其加以修正。

70620
您找到你想要的搜索结果了吗?
是的
没有找到

Java变量声明循环体内还是循环体外你选哪一个咧?

引言 最近刷知乎的时候看到一个比较有意思的问题,变量声明循环体内还是循环体外?这个问题有人认为应该定义循环体外,不应该定义循环体内。...很多java代码优化建议都有这么一条建议: 循环内不要不断创建对象引用 例如: for (int i = 1; i <= count; i++){ Object obj = new Object...这条建议应该也出现过很多公司的代码规范上了吧。下面我们就来分析下变量声明循环体内和变量声明循环体外的情况。...slot outsideLoop中,变量o和b分别占用了不同的slot,intsideLoop中,变量o和b复用一个slot。...从“局部变量作用域最小化”原则上来说,变量声明循环体内更合适一点,这样代码的阅读性更好。 结束 由于自己才疏学浅,难免会有纰漏,假如你发现了错误的地方,还望留言给我指出来,我会对其加以修正。

1.3K00

App性能优化浅谈

笔者在做产品开发的时候,也遇到性能瓶颈,测试工程师反馈了一些比较明显的问题,比如UI界面的过度绘制,列表滑动有明显卡顿,比较耗内存等等,但以往的都没有针对性的去做相应的优化,所以借着保证产品质量的出发点...永久代:存放VM和Java类的元数据,以及interned字符串和类的静态变量。 这里涉及到JVM的相关知识,这里不继续深入探讨。...优化点: 对常量使用static修饰符 使用静态方法 减少不必要的成员变量 尽量不要使用枚举,少用迭代器 对Cursor、Receiver、Sensor、File等对象,要注意它们的创建、回收与注册、反注册...将类、变量、方法等等的可见性修改为最小。 针对字符串的拼接,使用StringBuffer替代String。 不要在循环当中声明临时变量,不要在循环中捕获异常。...最后 写这篇文章的出发点也是对Android性能优化有个比较清楚的认识,任何事情都不可能一蹴而就,需要渐进,对一个初学者你谈优化很不现实,我们先把基本的做好,再去考虑相应的优化,笔者也不断学习当中

2.1K30

Java】循环语句for、while、do-while

专栏介绍 【Java】 目前主要更新Java,一起学习一起进步。 本期介绍 本期主要介绍循环语句for、while、do-while 文章目录 1....,从而结束 环,否则循环将一直执行下去,形成死循环。...③具体执行的语句 ④循环后,循环变量的变化情况 输出10次HelloWorld do...while 循环的特点:无条件执行一次循环体,即使我们将循环条件直接写成 false ,也依然会...原因是 for 循环结束,该变量就从 内存中消失,能够提高内存的使用效率。 已知循环次数的时候使用推荐使用 for ,循环次数未知的时推荐使用 while 。...扩展知识点 2.1 死循环 死循环: 也就是循环中的条件永远为 true ,死循环的是永不结束的循环。例如: while(true){} 。

6.7K10

【ES】199-深入理解es6块级作用域的使用

,但const声明也有一处与let声明不同,那就是const声明变量不能被赋值,无论是非严格模式下还是严格模式下,都不能对const声明变量进行赋值。...100 我们可以使用let声明变量i限制环中,此时再在循环作用域之外访问变量i就会报错了,因为let声明已经为循环创建了一个块级作用域。...如下: for(let i = 0;i < 100;i++){ //执行某些操作 } //报错 console.log(i); 6.循环中的创建函数 使用var声明变量的循环中,创建一个函数非常的困难...,因此不能将const声明用在for循环中,但可以将const声明用在for-in或者for-of循环中。...for-of循环是es6的新增的坏。。 7.全局作用域绑定 let,const声明与var声明还有一个区别就是三者全局作用域中的行为。

3.7K10

MySQL数据库,详解流程控制语句(四)

/*删除存储过程*/ DROP PROCEDURE IF EXISTS proc6; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc6(.../*删除存储过程*/ DROP PROCEDURE IF EXISTS proc7; /*声明结束符为$*/ DELIMITER $ /*创建存储过程*/ CREATE PROCEDURE proc7(...本⽂主要介绍了mysql中控制流语句的使⽤,请⼤家下去了多练习,熟练掌握 2. if函数常⽤select中 3. case语句有2种写法,主要⽤select、begin end中,select中end...后⾯可以省略case, begin end中使⽤不能省略case 4. if语句⽤begin end中 5. 3种循环体的使⽤,while类似于java中的while循环,repeat类似于java...循环中体中的控制依靠leave和iterate,leave类似于java中的break可以退出 环,iterate类似于java中的continue可以结束本次循环

2.6K10

Java代码评审歪诗!让你写出更加优秀的代码!

验-言 公共方法都要做参数的校验,参数校验不通过明确抛出异常或对应响应码: Java Bean验证已经是一个很古老的技术了, 会避免我们很多问题; 接口中也明确使用验证注解修饰参数和返回值, 作为一种协议要求调用方按验证注解约束传参...命-明 包/类/方法/字段/变量/常量的命名要遵循规范,要名副其实,这不但可以增加可读性,还可以起名的过程中引导我们思考方法/变量/类的职责是否合适 有意义很重要, 典型无意义命名: ?...-勋 不要在循环中调用服务,不要在循环中做数据库等跨网络操作; 频-品 写每一个方法时都要知道这个方法的调用频率,一天多少,一分多少,一秒多少,峰值可能达到多少,调用频率高的一定要考虑性能指标,考虑是否会打垮数据库...如果调用了外部依赖,一定要搞清楚这个外部依赖可以提供的性能指标,最好约定SLA; 轮-伦 不要重复造轮子,如果已经有成熟类库实现了类似功能,要优先使用成熟类库的方法,这是因为成熟类库中的方法都经过很多人的测试验证...使用Service成员变量: ?

5.4K20

OushuDB-PL 过程语言-控制结构

如果返回简单类型,那么可以 使用任何表达式,同时表达式的类型也将被自动转换成函数的返回类型,就像我们赋值中描述的那 样。如果要返回一个复合类型的数值,则必须让表达式返回记录或者匹配的行变量。...可选的label可以由EXIT和 CONTINUE语句使用,用于嵌套循环中声明应该应用于哪一层循环。 2)....如果声明了WHEN,EXIT命令只有expression为真时才被执行,否则将直接执行EXIT后面的语句。...如果声明了WHEN,CONTINUE命令只 有expression为真时才被执行,否则将直接执行CONTINUE后面的语句。...每次迭代name值自增1,但如果声明了REVERSE,name变量每次迭代中将 自减1,见如下示例: LOOP -- do something EXIT WHEN count > 100; CONTINUE

2.5K20

超全 | 只有高手才知道的C语言高效编程与代码优化方法(二)

使用递增循环计数器的代码不享有这种优化。 合并循环 如果一个循环能解决问题坚决不用二个。但如果你需要在循环中做很多工作,那么你并不适合处理器的指令缓存。...不仅程序指针需要改变,而且使用的变量需要压栈并分配新变量。 为提升程序的性能,函数这点上有很多可以优化的。 保持程序代码可读性的同时也需要代码的大小是可控的。...例如:while(n–){},这有时难于优化; 减少全局变量的使用; 除非像声明为全局变量,使用static修饰变量为文件内访问; 尽可能使用一个字大小的变量(int、long等),使用它们(而不是...递归可能优雅而简单,但需要太多的函数调用; 不在循环中使用sqrt开平方函数,计算平方根非常消耗性能; 一维数组比多维数组更快; 编译器可以一个文件中进行优化-避免将相关的函数拆分到不同的文件中...最后,最重要的是将编译器优化选项打开! 看上去很显而易见,但却经常在产品推出时被忘记。 编译器能够更底层上对代码进行优化,并针对目标处理器执行特定的优化处理。

3.6K20

滚雪球学Java(15):节约时间,提升效率:掌握JavaSE-while循环语句的技巧与窍门

每次循环中,我们打印出i的值,然后将i加1。当i等于5时,循环条件为false,循环结束。while循环的注意事项循环条件可以是任何返回布尔值的表达式,包括变量、常量、方法和关系运算符。...方法体中,声明了两个整数变量i和sum,分别用于记录当前遍历到的整数和总和。  然后,使用while循环来遍历从1到n的所有整数。每一次循环中,将当前的整数值累加到sum中,并将i递增1。  ...环中,我们将列表中的每个元素与目标元素进行比较,直到找到目标元素或到达列表的末尾。如果找到目标元素,我们将变量found设置为true,并终止循环。否则,我们将i递增,并继续查找下一个元素。...代码解析:  上述代码是一个列表中查找特定元素的方法。代码通过一个while循环来遍历列表,直到找到目标元素或者遍历完整个列表。具体分析如下:声明一个布尔变量found,并将其初始化为false。...声明一个整数变量i,并将其初始化为0。用于遍历列表的索引。进入while循环,条件是found为false并且i小于列表的大小。

9821

京东资深架构师代码评审歪诗

在此之前和讯网负责股票基金行情系统的研发工作,具备高并发、高可用互联网应用研发经验。 贾言验幻空越重, 命频异长。 依轮线日简, 接偶正分壮。言欢空月虫, 明勋品宜昌。...java bean验证已经是一个很古老的技术了,会避免我们很多问题,可参考: http://beanvalidation.org/ http://www.infoq.com/cn/news/2010/03...- 明勋品宜昌 命: 包 / 类 / 方法 / 字段 / 变量 / 常量的命名要遵循规范,要名副其实, 这不但可以增加可读性,还可以起名的过程中引导我们思考方法 / 变量 / 类的职责是否合适...: 不要在循环中调用服务,不要在循环中做数据库等跨网络操作 频: 写每一个方法时都要知道这个方法的调用频率,一天多少,一分多少,一秒多少,峰值可能达到多少,调用频率高的一定要考虑性能指标,...如果调用了外部依赖, 一定要搞清楚这个外部依赖可以提供的性能指标,最好约定 SLA 轮: 不要重复造轮子,如果已经有成熟类库实现了类似功能,要优先使用成熟类库的方法,这是因为成熟类库中的方法都经过很多人的测试验证

4.7K30

Java之for循环break、continue

for循环执行的次数是执行前就确定的。语法格式如下: ? 关于 for 循环有以下几点说明: 最先执行初始化步骤。可以声明一种类型,但可初始化一个或多个循环控制变量,也可以是空语句。...执行一次循环后,更新循环控制变量。 再次检测布尔表达式。循环执行上面的过程。 for循环的流程图 ? 【注意】for循环执行条件测试后,先执行程序部分,再执行跟表达式。 代码演示: ?...Java 增强 for 循环 Java5 引入了一种主要用于数组的增强型 for 循环。 Java 增强 for 循环语法格式如下: ?...声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等。 表达式:表达式是要访问的数组名,或者是返回值为数组(下一节讲解数组)的方法。... for 循环中,continue 语句使程序立即跳转到更新语句。 while 或者 do…while 循环中,程序立即跳转到布尔表达式的判断语句。 语法。

6.2K20

JAVA语言程序设计(一)04747

//public class 后面代表定义一个类的名称,类是java当中所有源代码的基本组织单位 关键字的概念与特征 完全小写的字母 根据编辑器去分。。...方法入门 方法:就是将一个功能抽取出来,把代码单独定义一个大括号内,形成一个单独的功能。...,一般可以分成四部分 初始化语句:坏开始最初执行,而且只做唯一一次 条件判断:如果成立,则坏继续,不成立坏退出 坏体:重复做的事情内容,若干行语句 步进语句:每次坏之后要进行的扫尾工作,每次坏结束都要这样...for坏 while坏 标准格式 while(条件判断){ 坏体 } 先执行初始表达式,看布尔表达式,满足就执行坏体跟步进表达式 do while 初始化语句...2、参数的类型不同 3、参数的多类型顺序不同 /* 比较俩个数据是否相等 参数分别为俩个byte类型、俩个short类型、俩个int类型、俩个long类型 并在main方法中进行测试 */

5.1K20

String 详解以及内存分析

Java 没有内置的字符串类型,而是标准 Java 类库中提供了一个预定义的类String,每个用双引号括起来的字符串都是 String 类的一个实例。...如果字符串 s 和 t 内容相等,则s.equals(t) 返回 true,否则返回 false. s 和 t 既可以是字符串变量,也可以是字符串常量,例如: “Hello”.equals(t); 要测试两个字符串除了大小写区别外是否是相等的... jdk5.0 之后 java 对字符串拼接做了编译器的优化处理 。...稍微优化一下。 ? StringBuilder 对象的创建在坏外面,这样就只创建了一个对象,比较好。 总结 我们循环体中需要尽量避免隐式或者显式创建 StringBuilder。...其实对于坏来说,尽量避免坏里创建对象,可以将创建对象这个操作放在坏外面,这样我们就让这个对象达到复用了。

76520

Python数据容器:集合

前言 Python 中,数据容器是组织和管理数据的重要工具,集合作为其中一种基本的数据结构,具有独特的特性和广泛的应用。本章详细介绍了集合的定义、常用操作以及遍历方法。...定义字面量:{元素1,元素2,元素3,元素4,...}定义变量变量名称 = {元素1,元素2,元素3,元素4,…}定义空元组:变量名称 =set()②特点:可容纳多个数据可容纳不同类型的数据(混装)可修改...for坏遍历:# 集合的遍历# 集合不支持下标索引,所以不能用while坏,可用for坏set1={1,2,3}for element in set1: print(f"集合的元素有{element...循环中将列表的元素添加至集合4.最终得到元素去重后的集合对象,并打印输出my_list = ['新闻', '传播', '新闻', '传播', 'Hi', 'Python', 'Hi', 'Python'..., 'best']# 定义一个空集合my_set=set()# 通过for坏遍历列表for element in my_list: # for坏中将列表元素添加至集合 my_set.add

2721

C语言基础——循环详解!

继续执行 环后面的代码 (3)执行完b 后,继续判断a是否满足条件。...由于while循环不会自行更改循环控 制变量的内容,所以while循环中为循环控制变量赋值的工作要由设计者自己来 做,完成后再回到步骤(2)重新判断是否继续执行循环。...语句先执行一次,进行判断,while先判断后执行。...结构如下: for ( [表达式 1]; [表达式 2 ]; [表达式3] ){语句4} 表达式1:一般为赋值表达式,给控制变量赋初值; 控制变量 表达式2:关系表达式或逻辑表达式,循环控制条件;控制条件...==================================== int i; //声明一个变量i for (i = 0; i < 10; i++) //1、给i赋值为0 2、判断i<10 为真执行循环

4.2K00

Java里认识汇编指令重排序

前言 编译器重排指令主要是为了优化程序的执行效率。编译器会根据程序的语义和指令的特性,对指令进行重新排序,使得程序执行时能够更快地完成。...例如,编译器可以将循环中的计算指令重新排序,以避免CPU缓存的缺失,从而提高程序的执行速度。 3....但是多线程环境中线程交替执行,由于编译器优化重排的存在,两个线程中使用的变量能否保证一致性是无法确定的,结果无法预测(类似答题顺序跟试卷顺序不一致)。...三、禁止指令重排 Java中,可以通过将变量声明为`volatile`或使用`synchronized`关键字来禁止指令重排。 1....使用volatile关键字 将变量声明为`volatile`可以禁止指令重排。

33870

JAVA 第二天 关键字

Goto 虽然为Java关键字,但是仅在C语言里面使用,Java不提供Goto语句 If Java编程语言的一个关键字,用来生成一个条件测试,如果条件为真,就执行if下的语句。...Implements Java(TM)编程语言的一个关键字,类的声明中是可选的,用来指明当前类实现的接口。...Instaceof 一个二操作数的Java(TM)语言关键字,用来测试第一个参数的运行时类型是否和第二个参数兼容。...它表示这个方法或变量只能被这个类的其它元素所访问。 Protected 方法和变量声明中使用,它表示这个方法或变量只能被同一个类中的,子类中的或者同一个包中的类中的元素所访问。...Public 方法和变量声明中使用,它表示这个方法或变量能够被其它类中的元素访问。 Return 用来结束一个方法的执行。它后面可以跟一个方法声明中要求的值。

87670
领券