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

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

事实上这个语句会报2次“违反了PRIMARY KEY约束…”,原因是@t这个表变量,并不是在每一圈都重新声明一个新的,而是声明1次后就一直沿用,由于该表具有主键约束,所以之后的两圈在插入的时候,由于已经存在相同主键...理解这一点很重要,因为这与C#等编译语言非常不同,C#中每一圈声明的变量都相当于重新建一个,与上一圈的毫无关系,但在sql中不能这么思考。...其实这个问题本质上是一个变量作用域问题,只不过SQL中的变量作用域,与C#等语言按语句块划分不一样,SQL的变量作用域是【批】,这一点在MSDN中有说。...原因就在于声明语句比较特殊,它并不依赖位置,系统“见到”就算数,所以不管变量在多深的语句块中声明,它在本批接下来的语句中都是有效的。...回到开头的问题,现在我们清楚,虽然变量在循环中声明,但它并不会被多次执行,甚至不是在第1圈的时候执行,而是在某个时机由系统将所有声明统一执行,大概类似C#的静态字段,不管定义在哪里,CLR会确保在使用该类前完成初始化

1.7K20

【Python】循环语句 ⑥ ( 变量作用域 | for 循环临时变量访问 | 分析在 for 循环外部访问临时变量的问题 | 在 for 循环外部访问临时变量的正确方式 )

for 循环的临时变量 在 循环体外部也可以访问 , 但是不建议这么做 , 代码不够规范 ; 如果需要在外部访问 for 循环的临时变量 , 建议将该 临时变量 预定义在 for 循环的外部 , 然后在后续的所有代码中可以访问该...临时变量 ; 一、变量作用域 1、for 循环临时变量访问 下面的 for 循环中 , 临时变量 i 变量 的作用域范围 , 仅限于 for 循环语句内部 , 但是在 for 循环外部可以访问到临时变量...for 循环中的临时变量 i # 但是此处可以访问到 临时变量 i print(i) 理论上说 , for 循环中的 临时变量 是 临时的 , 只在 for 循环内部生效 , 在 for 循环的外部不应该生效...; 但是 如果在 for 循环外部 访问该临时变量 i 是可以访问的 , 上述代码的执行结果如下 : 0 1 2 2 2、分析在 for 循环外部访问临时变量的问题 下面分析一下上述 在 for 循环外部访问...循环中的 # i 变量是 for 循环的 临时变量, 仅在 for 循环内部生效 for i in range(3): print(i) 代码 , 运行后打印出 0 1 2 在 for 循环外的 #

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

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

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

    73820

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

    引言 最近刷知乎的时候看到一个比较有意思的问题,变量声明在循环体内还是循环体外?这个问题有人认为应该定义循环体外,不应该定义在循环体内。...这条建议应该也出现过在很多公司的代码规范上了吧。下面我们就来分析下变量声明在循环体内和变量声明循环体外的情况。...27.476 ns/op ForEachBenchMark.outsideLoop 100 avgt 5 584.853 ± 20.289 ns/op 我们可以发现不管在循环外创建对象和循环内创建对象时间几乎都是一样的...在stack frame中定义了4个slot, 而intsideLoop只定义了3个slot 在outsideLoop中,变量o和b分别占用了不同的slot,在intsideLoop中,变量o和b复用一个...从“局部变量作用域最小化”原则上来说,变量声明在循环体内更合适一点,这样代码的阅读性更好。 结束 由于自己才疏学浅,难免会有纰漏,假如你发现了错误的地方,还望留言给我指出来,我会对其加以修正。

    1.4K00

    计算范围内的质数个数,尽可能避免循环次数|Java 刷题打卡

    首先我们得知道什么叫质数(除了1和自己本身以外不能被其他数整除的叫做质数)首先就是暴露破解。咋一看感觉除了暴力破解也没其他办法了。暴力实现的方式也很简单两层循环就可以解决了。...所以我们在算一个数是否是质数的时候只需要循环截止到根号public int countPrimes(int n) { int total = 0; for (int i = 2; i 在循环检测中就不需要在判断他们是不是质数了。这样就大大的减少了我们排查的次数当我们检测2是质数时,对应的4,6,8,10,12,14都将被标记为合数。...但是在执行上还是有提高的空间。而且我们在分析下埃筛法的执行过程不难发现好多数据是重复的。在上面的演示图中我也是通过不同颜色来区分不同质数的延伸的。比如说10第一次被2*5的2质数渲染成合数了。...为了避免类似10=2*5 ,乘数位置交换的问题,我们可以在延伸的时候从质数的平方开始,因为质数的之前肯定会被之前的质数渲染public int countPrimes3(int n) { int

    21710

    Tkinter mainloop() 循环的逻辑,以及变量为什么不会被重新赋值为初始值?

    1、问题背景在使用 Tkinter 开发 GUI 程序时,您可能会遇到这样的疑问:为什么在使用 window.mainloop() 循环时,变量不会被重新赋值为它们的初始值?...也许我对 window.mainloop() 的作用完全误解了,但如果它确实使程序不断循环执行代码,那么为什么不将变量重新赋值为它们的初始值呢?...它只是不断地从事件队列中获取事件,然后将事件分发给相应的处理函数。处理函数可以修改变量的值,但不会影响其他代码中的变量。也就是说,变量的值只会在处理函数中被修改,而在其他代码中不会被修改。...但是,window.mainloop() 并不会重新执行 GUI 代码,所以其他代码中的变量(如 x、y、a、b)不会被修改。...希望这篇技术文章能够帮助您理解 Tkinter window.mainloop() 循环的逻辑,以及变量为什么不会被重新赋值为初始值。

    28710

    ES6语法学习(let与var区别、块级作用域、const命令)

    (let i=0;i<10;i++){ //执行代码 } console.log(i);//报错i is not defined 1.1.2示例: 下面的代码中,变量i是var声明的,所以i是一个全局变量在全局范围内都有效...i是let声明,当前的i只在本轮循环中有效,所以每一次循环都是一个新的变量,于是最后输出6。...i都是重新声明的,那么它怎么知道上一轮循环的值从而进行计算出本轮循环的值呢?...,就会报错 var x = x;//不报错 let y = y;//报错ReferenceError 1.4-不允许重复声明 let不允许在相同的作用域内重复声明同一个变量 function a...: 1.有变量提升 2.没有块级作用域,是函数作用域 3.能重复声明 4.可以重新赋值  let声明变量: 1.没有变量提升 2.有块级作用域 3.不能重复声明 4.可以重新赋值 02-块级作用域 2.1

    1.1K00

    JS学习系列 03 - 函数作用域和块作用域

    在 ES5 及之前版本,JavaScript 只拥有函数作用域,没有块作用域(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用域,{ } 内是单独的一个作用域。...采用 let 或者 const 声明的变量会挟持所在块的作用域,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用域和块作用域。...函数中的作用域 函数作用域的含义是指,属于这个函数的任何声明(变量或函数)都可以在这个函数的范围内使用及复用(包括这个函数嵌套内的作用域)。...括号来为 let 创建一个用于绑定的块。 还有一点要注意的是,在使用 var 进行变量声明的时候会存在变量提升,提升是指声明会被视为存在于其所出现的作用域的整个范围内。...// 报错,i is not defined 复制代码 for 循环头部的 let 不仅将 i 绑定到 fir 循环的块中,事实上它将其重新绑定到了循环的每一个迭代中,确保上一个循环迭代结束时的值重新进行赋值

    1.6K10

    JS学习系列 03 - 函数作用域和块作用域

    在 ES5 及之前版本,JavaScript 只拥有函数作用域,没有块作用域(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用域,{ } 内是单独的一个作用域。...采用 let 或者 const 声明的变量会挟持所在块的作用域,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用域和块作用域。...函数中的作用域 函数作用域的含义是指,属于这个函数的任何声明(变量或函数)都可以在这个函数的范围内使用及复用(包括这个函数嵌套内的作用域)。...括号来为 let 创建一个用于绑定的块。 还有一点要注意的是,在使用 var 进行变量声明的时候会存在变量提升,提升是指声明会被视为存在于其所出现的作用域的整个范围内。...// 报错,i is not defined for 循环头部的 let 不仅将 i 绑定到 fir 循环的块中,事实上它将其重新绑定到了循环的每一个迭代中,确保上一个循环迭代结束时的值重新进行赋值。

    12910

    使用letconst定义变量的场景

    ,但是循环结束后,它并没有消失,释放,而是泄露成了全局变量,这样会造成全局变量的污染 解决办法: 若使用let定义变量,则变量不会被提升置作用域顶部,它只会在它定义的块级作用域内生效 注意事项 使用let...,在全局范围内都是有效的,所以每一次循环,新的i值都会覆盖旧值,导致最后输出的是最后一轮的i的值 如果使用let,声明的变量仅在块级作用域内有效,最后将输出8 02 块级声明及块级(词法)作用域 正因为...Es5中使用var声明的变量,没有块级作用域,会污染全局变量,如果使用不当,会产生一些达不到自己预期的效果,所以在Es6中就有了块级作用域 块级作用域:用于声明在指定的块的作用域之外无法访问的变量 函数内部...,只要在声明之前使用这些定义的变量,就会报错 在代码块内,使用let,const命令声明变量之前,该变量都是不可用的,这称为暂时性死区(TDZ),换言之,需要提前声明并且赋值,就可以使用 if(true...Bug 如果希望在全局对象下定义变量,可以使用var 总结 块级作用域绑定的let,const为javaScript引入了词法作用域,使用它们声明变量不会提升,而且只可以在声明这些变量的代码块种使用 使用

    1K20

    JS进阶:作用域和作用域链

    函数作用域,是指声明在函数内部的变量,和全局作用域相反,局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部。...正因为如此, ES6 引入了块级作用域,让变量的生命周期更加可控。 3.块级作用域 块级作用域可通过新增命令let和const声明,所声明的变量在指定块的作用域外无法被访问。...如果一个标识符已经在代码块内部被定义,那么在此代码块内使用同一个标识符进行 let 声明就会导致抛出错误。...i是var命令声明的,在全局范围内都有效,所以全局只有一个变量i。...你可能会问,如果每一轮循环的变量i都是重新声明的,那它怎么知道上一轮循环的值,从而计算出本轮循环的值?

    2.6K20

    《你不知道的JavaScript》:函数作用域和块作用域

    常见的作用域形式 在JS中,最常见的作用域是函数作用域,其他结构通常不会创建作用域。但随着js的迭代,现在也有了块作用域,将在后面讲到。...而函数作用域的含义是指:属于这个函数的全部变量都可以在整个函数的范围内使用及复用,包括在嵌套的函数作用域中也可以使用。 函数作用域的常规套路是,先声明一个函数,然后向函数中添加代码实现。...块作用域 在ES5及之前版本中,js中的块作用域形同于无,实在要说的话,也只有try-catch中的catch部分定义的变量所在作用域是catch块中的,其他的都只是样子像,而本质上都不是块作用域,例如...let关键字可以将变量绑定到所在的任意作用域中,通常是{...}内部,也就是说,let关键字为其声明的变量隐式的定义了所在的块级作用域。 let关键字发挥作用的典型在于for循环。...事实上,for循环头部的let不仅将i绑定到for循环的块中,在每次循环开始时,还将其重新绑定到新的循环迭代中去,确保使用上一个循环迭代结束时的值重新赋值。

    96830

    es6中的Let和Const详解

    Let 用于声明一个变量 特点 let 声明的变量只在自身的块级作用域有效,存在暂时性死区 不能重复声明(会报错提示已经定义) 不会预处理,不存在变量提升 应用 循环遍历监听 使用 let 替换 var...i是var命令声明的,在全局范围内都有效,所以全局只有一个变量i。...每一次循环,变量i的值都会发生改变,而循环内被赋给数组a的函数内部的console.log(i),里面的i指向的就是全局的i。...let bar = 2; 暂时性死区 当你在一个块里面,利用 let 声明一个变量的时候,在块的开始部分到该变量的声明语句之间,我们称之为临时性死区,你不可以在这个区域内使用该变量,直到遇到其 let...凡是在声明之前就使用这些变量,就会报错。 总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。

    56130
    领券