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

oracle 笔记

你需要执行一个 SQL 语句,但是 SQL 语句语法规定需要指定一个表,为此 Oracle 设计了一个只有一行一列的表 DUAL,我们可以使用这个表来执行一些不需要表的 SQL 语句。...SQL语句中使用 LIKE 前面,我们介绍了尽量避免在SQL语句的WHERE子句中使用函数,因为这样做会使该字段上的索引失效,影响SQL 语句的性能。..., 0.0) + NVL(BONUS, 0.0) >= 3000.0; 有没有更简单的办法呢?...在 SQL 的世界中 CASE 语句有类似的效果。下面简单的介绍 CASE 语句的用法。...CASE使用案例 3 假设让你把张三的生日更新成1949-10-1,李四的生日更新成1997-7-1等,类似这样的更新有很多。该怎么办呢?非常简单,大多数人会这么做。

4.1K30

Druid 介绍及配置「建议收藏」

Druid有没有参考配置 不同的业务场景需求不同,你可以使用我们的参考配置,但建议你仔细阅读相关文档,了解清楚之后做定制配置。...Druid中有没有类似Jboss DataSource中的ExceptionSorter ExceptionSorter是JBoss DataSource中的优秀特性,Druid也有一样功能的ExceptionSorter...我的应用已使用DBCP,是代码中写死的,怎样更换为Druid? 可以的,Druid提供了一个中完全平滑迁移DBCP的办法。.../lib/中删除dbcp-xxx.jar 按需要加上配置,比如JVM启动参数加上-Ddruid.filters=stat,动态配置druid的filters 这种用法,使得可以在一些非自己开发的应用中使用...有一些SQL执行很慢,我希望日志记录下来,怎么设置?

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

    《深入浅出MySQL》问答录(五)

    ---- Q:如果我只想对部分列套用CASE表达式,应该怎么做呢? A:可以加上WHERE,可以在END后加上WHERE子句。这样,CASE就只会套用在符合WHERE子句的列上。...---- CASE表达式可以搭配UPDATE以外的语句吗? A:why not ---- Q:讲到MIN,如果查询中的列有NULL,这会有上面影响吗? A:好问题。...那有没有更好的办法,其实在主语言中,这不过就是个分支语句的事情嘛,奈何SQL语言我不熟啊。。。...没事,一直以来不懂,从今以后懂了: UPDATE my_table SET new_column = CASE WHEN column1 = somevalue1 THEN newvalue1...WHEN column2 = somevalue2 THEN newvalue2 ELSE newvalue3 END; ORDER BY排序 1、升序排序:ASC | 降序排序:DESC 2、SQL

    44411

    《SQL Cookbook》 - 第一章 检索数据

    朋友推荐了一本书《SQL Cookbook》,翻译过来就是《SQL经典实例》,讲的都是SQL编写层面的案例,例如获得随机数、NULL值判断、求中位数、日期计算等,都是日常工作中可能用到的,但是有些知识点可能稍微模糊...在SELECT语句中指定具体的列名,可以确保查询语句不会返回无关的数据。当在整个网络范围内检索数据时,这样做更重要,因为他避免了将时间浪费在检索不需要的数据上。 2....新的列名被称作别名,他会让检索结果更易于理解,对于一些数据库,可以省略AS关键字,但所有的数据库都支持这个关键字。 3....MySQL中可以用concat连接多列的值, select concat(cname, ' WORKS AS A ', job) from emp; DB2、Oracle和PG使用竖线进行连接, select...ELSE子句是可选的,若没有他,对于不满足测试条件的行,CASE表达式会返回NULL, select ename, sal, case when sal <= 2000 then 'UNDERPAID

    88720

    使用decode函数

    大家好,又见面了,我是你们的朋友全栈君。 Decode函数使用: Oracle 的decode函数蛮有意思,是oracle独有的,国际标准SQL中并没有decode函数。...decode函数也可以做判断,可以实现case…when…then…else..end 和 if..then..else..end if 同样的功能。...但是对于600W的记录,最终结果只有0.01到0.02秒的查询,实在没有办法得出上面的结论,因为这个差别实在是太小,以至于任何其他的一些影响都足以改变测试结果,如要一定要得出结论,那么结论就是3种方式的效率基本相同...不过由于CASE表达式更加灵活,使得以前DECODE必须运用的一些技巧得以简化,这时使用CASE方式,确实可以得到一些性能上的提高,比如: SQL> SELECT DECODE(SIGN(OBJECT_ID...本身的性能要高于DECODE,事实上如果这里使用SIGN并利用CASE的所谓高效语法: SQL> SELECT CASE SIGN(OBJECT_ID) WHEN 1 THEN ‘+’ 2 WHEN

    80910

    使用mysqldump导出数据库

    它主要产生一系列的SQL语句,可以封装到文件,该文件包含有所有重建您的数据库所需要的SQL命令如CREATE DATABASE,CREATE TABLE,INSERT等等。...可以用来实现轻量级的快速迁移或恢复数据库。是mysql数据库实现逻辑备份的一种方式。本文描述了mysqldump的一些重要参数以及给出了相关示例供大家参考。...#以上2个参数未使用的情况下,在转储结果之前会把全部内容载入到内存中,对于较大的数据库转储将严重影响性能。   #缺省情况下这2个参数为开启状态。...#skip-opt与前2个参数相反,在转储之前先load到内存中。   ...The exception is when                         using --lock-all-tables or --master-data: in this case

    3.7K20

    征集佳句-精妙SQL语句收集

    ,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作,方便自己写SQL时方便一点,想贴上来,一起看看,同时希望大家能共同多多提意见,也给我留一些更好的佳句,整理一份《精妙SQL速查手册》,不吝赐教...DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。...B: EXCEPT 运算符 EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。...where 范围 15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)...可以方便地实现多重选择,类似select 中的case。

    57040

    web_for_pentest_II writeup

    听说新出了web for pentest2,正好没什么事,那就来做做看吧… SQL injections example1 打开看到是一个登陆框,猜测是没有过滤,那么先输入个单引号吧,看看有没有什么过滤...不知道为什么这类型的题目都会报500,没办法,只能看官方文档猜猜看,基本说的很清楚,mysql会忽略尾随在字符串后面的空格,利用这种方式,就可以进行注册覆盖了,还是比较简单的。...大概说我们很容易通过枚举单词来比较验证码的正确,类似于弱口令吧。 example6 这次的比较清晰了,打开是很弱的验证码,找一些工具就可以识别这样的图片了,官方文档是这么说的。...Only submit a value if it only contains of lower case characters....他推荐了ocr tool这个工具,在识别的时候还可以加一些优化,剔除一些不是单词的,在剔除一些只有小写字母的。 example7 只是加了一些蓝色的线基本是不解决问题的,很容易处理这样的图片。

    36850

    神奇的 SQL 之 CASE表达式,妙用多多 !

    CASE表达式 之概念   相信大家都用过CASE表达式,尤其是做一些统计功能的时候,用的特别多,可真要说什么是 CASE表达式,我估计还真没几个人能清楚的表述出来。...CASE表达式 之妙用   上面讲了 CASE表达式 的理论知识,感觉不痛不痒,那么接下来我们进入实战篇,结合一些场景来看看 CASE表达式 的妙用   行转列     可能我们用的更多的是 IF(MySQL...)或 DECODE(Oracle),但这两者都不是标准的 SQL,更推荐大家用 CASE表达式,移植性更高     假设我们有如下表,以及如下数据 CREATE TABLE t_customer_credit...最好的做法确实是这样,但这得需要我们在设计之初的时候能考虑得到,或者有这样的需求,假设我们设计之初没有这样的需求,而我们也没考虑到,那么有没有什么办法来实现了?...特别完美,这个技巧的应用范围很广,值得我们掌握   CHECK 约束 注意:CHECK 是标准的 SQL,但是 MySQL 却没有实现它,所以 CHECK 在 MySQL 中是不起作用的!

    78130

    可编程的SQL是什么样的?

    支持更多数据源 传统SQL是假定你在一个数据源中的,因为你只能按库表方式去使用,在普通Web开发里,是你配置的数据库。而在大数据里,一般是数据仓库或者数据湖。...原生的SQL是很难复用的,所以没有形成类似的机制,更多的是随用随写。 但是随着SQL能力的扩展,在流,在批,在机器学习上的应用越来越多,能写越来越复杂的逻辑,也慢慢有了更多的可复用诉求。...宏函数 函数是代码复用的基础。几乎任何语言都有函数的概念。我们在SQL中也引入的宏函数的概念。但这个宏函数和 原生的SQL中的函数比如 split, concat 等等是不一样的。...from mock_data as output; Python脚本支持 在可编程SQL里, SQL是一等公民, Python只是一些字符串片段。...对于一个很复杂的SQL 语句,里面可能存在多个类似sum /case when的重复语句,那么我们就可以使用这种方式了。而且可以做到一处修改,处处生效。

    66130

    SQL之CASE WHEN用法详解

    NUMBER 简单CASE WHEN函数只能应对一些简单的业务场景,而CASE WHEN条件表达式的写法则更加灵活。...CASE WHEN条件表达式函数:类似JAVA中的IF ELSE语句。 格式: CASE WHEN condition THEN result [WHEN...THEN...]...’,这是一种错误的写法,正确的写法应为: CASE WHEN score IS NULL THEN '缺席考试' ELSE '正常' END 场景2:现老师要统计班中,有多少男同学,多少女同学,并统计男同学中有几人及格...WHEN E_TYPE = 0 THEN E_VALUE ELSE 0 END) AS WATER_ENERGY,--水耗 SUM(CASE WHEN E_TYPE = 1 THEN E_VALUE...WHERE P_LEVEL = 2) 场景5:结合max聚合函数 CASE WHEN 函数使用起来简单易懂,此篇文章只作了简单的使用介绍,还需在实际工作中根据业务场景不同来灵活使用。

    68920

    程序员工作中的巧思

    [xiuse.png] 孽起 事情是这样的,最近在开发一个 仅限内部使用 的数据分析系统,我做后端,另外一个哥们做前端。...[数据看板] 要实现这个需求,一种最简单的方式就是,直接将用户在界面上输入的 SQL 字符串发给后端保存,需要看数据时,后端再用这个字符串从数据库中查询数据即可。...但是,数据业务中的 SQL 语句可比这复杂得多,包含各种四则运算、IF ... ELSE 条件判断、CASE ... WHEN ......分支,字符串、日期类型处理函数,还有各种聚合函数等,比如下面这个 SQL: select a as b, sum(case when (false) then d / a else 2 end) as...既然没办法直接搜到现成的 SQL 校验类库,那不妨来个 移花接木,想一想其他的类库中是否包含 SQL 解析功能,如果解析失败,不就表示 SQL 非法,校验不通过么!

    77831

    数据库行转列的sql语句(zt)

    当科目增多或者实际科目没有这么多时统计的结果就不那么完美了。换言之,这种方法是静态的,将科目在sql语句里写死了。...      该办法大致思想类似前一种。...用了group by就会解决扫描的效率问题,因为sum是计算的每个分组之类的。本方法的技巧之处在于case when的使用。        这个办法还是不能满足标准2。...在@s的第一次累加中的代码中一句from CJ group by subject很是有技巧性,可见简单的select * from table t where .....也是这么变化无穷,不得不佩服sql或者说关系型数据库的智慧。 本人收获     a.认真的分析一个简单的问题的来龙去脉是很有意义的事情,浮躁的学风会让你花费大量的时间结果一无所获。

    89910
    领券