select count(virtualacc) into v_count  from T_ATMMONITOR WHERE virtualacc = v_number;

用于存储过程中,是把count(virtualacc)统计的数量值赋予变量v_count,在后续的存储过程中调用v_count变量。

在sql语句中

select into from与insert into select 区别

语法:

insert into table2(field1,field2,。。。)select value1,value2,。。。from table1

要求table2必须存在

truncate,delete,drop三者的区别

1.truncate与不带where条件的delete意义一样,删除全部行的内容

2.truncate删除表内容,释放空间,执行速度快,保留表结构

delete 删除表内容,不释放空间,保留表结构

drop删除表内容和表机构,释放空间

table2存在,可以向table2加入符合列类型的内容,包括常量,注意,导入常量后,该列的所有值都是常量,如图所示

insert into T_ATMMONITOR (
     ATMNUM
    ,VIRTUALACC
    ,CORPID
    ,INVMONEY
    ,DAYMONEY
    ,DATAGETTIME
    ,CUTOFFMONEY
    ,CUTOFFTIME
   ) select atmnum, v_number, corpid, v_now_money, v_out_money, current TIMESTAMP, 0, current TIMESTAMP
    from t_atminfo where VIRTUALACC = v_number;

注意在t_atminfo表中不存在v_now_money,v_out_money,0这样的字段值,这些可以作为常量插入到t_atmmonitor

select into from语句

语法

select value1,value2 into table2 from table1

select ID,Name into table1 from table2

要求table2不存在,因为在插入的时候,系统自动创建table2,如果之前table2已经存在,系统提示表已经存在

那如果我想要MyTable2中的Name列,那我也仅仅是需要把Name列select出来,然后添加到新表中即可。

replace函数

replace(c1,c2[,c3])

在字符串c1中找到字符串c2,替换成c3.

若c3为空,则在c1中删除所有c2.
replace('123123tech', '123');	would return 'tech'
replace('123tech123', '123'); would return 'tech'
replace('222tech', '2', '3'); would return '333tech'
replace('0000123', '0'); would return '123'
replace('0000123', '0', ' '); would return ' 123'
nvl函数
if else 类似

nvl(str,1)

if str ==null
return 1;
else return str;
coalesce函数
语法  COALESCE ( expression [ ,...n ] )

返回表达式中第一个非空表达式,如有以下语句: 

  SELECT COALESCE(NULL,NULL,3,4,5) FROM dual
  其返回结果为:3
case when的用法
在储存过程中,这句是什么意思SUM(CASE WHEN ISNULL(A.ReceiveQty,0)>0 THEN 1 ELSE 0 END) AS SumReceiveRolls,
A表里ReceiveQty大于0,值为1,否则为0,
然后把这些1,0加起来,当成一列(SumReceiveRolls)查询出来。
case coalesce(c.limit, 1) when 0 then 1 else c.limit end
coalesce函数是去null的,如果c.limit值不为null,则coalesce(c.limit,1)就是c.limit本身值

DB2查询表中前10条记录
select * from t_user where corpid='901010300' order by userid desc fetch first N rows only
oracle数据库查询
select * from t_user where rownum<=10
timestamp数据类型查询语句
select * from t_authlog where to_char(logtime ,'yyyymmdd hh24:mi:ss')>'20150316 23:59:59'
存储过程解析

SELECT count(PLANNUM) into v_count FROM T_CASHREPNPLAN where CORPID = v_corpid and plannum = v_plannum and PLANSTATE = '04';

注:count(plannum)转换成into v_count的变量

if v_count = 0 then  注:如果这个变量统计为0,显示97
  set v_ret = '97';
  goto GOTO_RET;
 end if;


数据库字段是timestamp类型,查询区间的数据
select * from t_authlog where logtime between timestamp('2015-3-18 10:10:10') and timestamp('2015-3-19 15:40:20') 表中增加列,并限定默认字段的值
alter table t_warning add column overdue char(1) with default '0';
查询当前日期的数据
db2 => select * from t_compinvmonitor where date(gettime) = current date

存储过程sql语句的更多相关文章

  1. 一次性删除数据库所有表和所有存储过程 SQL语句

    一次性删除数据库所有表和所有存储过程 SQL语句 今天转移数据库数据,需要把数据库原来的表和存储过程清空.删除所有的表:如果由于外键约束删除table失败,则先删除所有约束: --/第1步****** ...

  2. 基于ORACLE建表和循环回路来创建数据库存储过程SQL语句来实现

    一个.概要 在实际的软件开发项目.我们经常会遇到需要创造更多的相同类型的数据库表或存储过程时,.例如.假设按照尾号点表的ID号,然后,你需要创建10用户信息表,的用户信息放在同一个表中. 对于类型同样 ...

  3. SQL语句练习手册--第四篇

    一.变量那点事儿 1.1 局部变量 (1)声明局部变量 DECLARE @变量名 数据类型 ) DECLARE @id int (2)为变量赋值 SET @变量名 =值 --set用于普通的赋值 SE ...

  4. MySQL存储过程动态SQL语句的生成

    用Mysql存储过程来完成动态SQL语句,使用存储过程有很好的执行效率: 现在有要求如下:根据输入的年份.国家.节假日类型查询一个节假日,我们可以使用一般的SQL语句嵌入到Java代码中,但是执行效率 ...

  5. Entity Framework Code First执行SQL语句、视图及存储过程

    1.Entity Framework Code First查询视图 Entity Framework Code First目前还没有特别针对View操作的方法,但对于可更新的视图,可以采用与Table ...

  6. SQL存储过程分页(通用的拼接SQL语句思路实现)

    多表通用的SQL存储过程分页 案例一: USE [Community] GO /****** Object: StoredProcedure [dbo].[Common_PageList] Scrip ...

  7. sql存储过程比sql语句执行慢很多

    参数嗅探的问题 原因:(1)可能是发生了参数嗅探,第一次赋给存储过程的输入参数,会为该存储过程生成一个基于输入参数的执行计划,因此如果第一次输入的参数不具有代表性(例如大部分查询输入的参数都是A值,但 ...

  8. 总结一些关于操作数据库是sql语句还是存储过程问题

    总结一些关于操作数据库是sql语句还是存储过程问题 程序中,你跟数据的交互,需要向数据库拿数据.更改数据库的数据等,这些操作,本身不是程序完成的,而是程序发命令给数据库去做的,不管是通过sql语句方式 ...

  9. SQL 语句调用这个存储过程,生成顺序编码

    一直很讨厌存储过程,没想到今天帮了我大忙啊,或许会因为今天让我慢慢喜欢上存储过程吧,不多说了,切入正题 在使用数据库的时候,难免要在使用过程中进行删除的操作,如果是使用int类型的字段,令其自增长,这 ...

随机推荐

  1. sendUserActionEvent() mView== null after clicking on button

    this is not a problem related to your code, but related to S4 android version. Same question has bee ...

  2. Wise Registry Cleaner Pro(智能注册表清理) V9.31 绿色版

    软件名称: Wise Registry Cleaner Pro(智能注册表清理)软件语言: 简体中文授权方式: 免费试用运行环境: Win7 / Vista / Win2003 / WinXP 软件大 ...

  3. FileReader和FileInputStream的区别

    1.FileReader和FileInputStream的区别: FileReader.FileWriter处理的是文本文件. FileInputStream/FileOutputStream是继承I ...

  4. List集合分页显示

    package com.mshc.util; import java.util.Arrays; import java.util.Collections; import java.util.List; ...

  5. linux 命令展示该目录下的所有子目录及文件结构 tree

    1. apt-get install tree 2. tree -d -L 1 解释: tree :显示目录树: -d : 只显示目录: -L 1 : 选择显示的目录深度为1 , 只显示一层深度. 目 ...

  6. SVN解锁失败的解决办法

    背景:在版本发布后,本人把工程文件上锁后,进行过修改但没有进行上传.后面一段时间后,开发人员需要进行修改提交,发现解锁不成功. 使用解锁命令时:提示如下: If you want to break t ...

  7. Myeclipse2014中,新建部署Maven项目

    一.环境 1.1 myeclipse2014 1.2 maven3.2.1 1.3 jdk1.7 上述环境配置可参照我之前编写的maven搭建方面的文档.本文着重介绍myeclipse2014下mav ...

  8. java链接mysql添加中文和模糊查询

    如下内容为转载 http://sunshinechen2008.blog.163.com/blog/static/107585374201162442643967/     mysql如果不对乱码处理 ...

  9. 《JavaScript高级程序设计》读书笔记 ---RegExp 类型

    ECMAScript 通过RegExp 类型来支持正则表达式.使用下面类似Perl 的语法,就可以创建一个正则表达式.var expression = / pattern / flags ; 其中的模 ...

  10. AMD规范

    common.js主要语法就是 var math=require('math'); math.add(2,3); require()用于加载模块就行了. 二行math.add(2, 3),在第一行re ...