sql 容易被忽视的点】的更多相关文章

1 dual select查询语句只有select就可以,但为了规范,凑结构,可以加个dual 例:select now() from dual; 这个概念是Oracle中的.在mysql中可写可不写. 2 drop,delete,truncate的区别 drop用于删除数据库,数据表的字段,删除表 delect: 1)可以带条件删除 2)可以删除全表数据,但只能删除表的数据,不能删除表的约束 使用delete from删除的数据可以回滚 truncate用于删除全表的数据 1)不能带条件删除…
Oracle数据库下载: 推荐去Oracle官网下载 官方网址链接:https://www.oracle.com/database/technologies/oracle-database-software-downloads.html 进入后选择自己需要下载的版本,这里呢以Oracle 11g为例 找到版本之后然后选择对应的系统的版本(以我的电脑为例,WindowsX64位系统的) 找到之后点击箭头指示的See All 点击后发现有两个文件需要下载,而且还是上锁的,这时候两个随便点击一个 然后…
原文:SQL开发中容易忽视的一些小地方(五) 背景: 索引分类:众所周知,索引分为聚集索引和非聚集索引. 索引优点:加速数据查询. 问题:然而我们真的清楚索引的应用吗?你写的查询语句是否能充分应用上索引,或者说你如何设计你的索引让它更高效? 经历:以前本人只知道索引的好处,但是是否能够真正让它发挥作用,并无太多理论,为些本人做了些DEMO,来简单说明下什么情况下才能充分利用索引. 案例: 这里建立一个学生表:有如下字段,此时表中没有建立任何索引. CREATE TABLE [dbo].[stud…
原文:SQL开发中容易忽视的一些小地方(一) 写此系列文章缘由: 做开发三年来(B/S),发现基于web 架构的项目技术主要分两大方面: 第一:C#,它是程序的基础,也可是其它开发语言,没有开发语言也就不存在应用程序. 第二:数据库,现在是信息化世界,大多数信息都可以通过数据库存储来交换信息.常与应用程序互相交流信息. 但在SQL开发应用时,我们往往只观注些常用的方法(insert delete select update),对些小细节方面(系统存储过程,函数的应用,优化分析)研究的并不多或者是…
原文:SQL开发中容易忽视的一些小地方(二) 目的:继上一篇:SQL开发中容易忽视的一些小地方(一) 总结SQL中的null用法后,本文我将说说表联接查询. 为了说明问题,我创建了两个表,分别是学生信息表(student),班级表(classInfo).相关字段说明本人以SQL创建脚本说明: 测试环境:SQL2005 CREATE TABLE [dbo].[student](     [ID] [int] IDENTITY(1,1) NOT NULL,     [sUserName] [ncha…
原文:SQL开发中容易忽视的一些小地方(六) 本文主旨:条件列上的索引对数据库delete操作的影响. 事由:今天在博客园北京俱乐部MSN群中和网友讨论了关于索引对delete的影响问题,事后感觉非常汗颜,因为我的随口导致错误连篇.大致话题是这样的,并非原话: [讨论:] delete course where classID=500001 classID上没有创建任何索引,为了提高删除效率,如果在classID上创建一个非聚集索引会不会提高删除的效率呢? 我当时的观点:不能. 我当时的理由:数…
原文:SQL开发中容易忽视的一些小地方( 三) 目的:这篇文章我想说说我在工作中关于in和union all 的用法. 索引定义 : 微软的SQL SERVER提供了两种索引:聚集索引(clustered index,也称聚类索引.簇集索引)和非聚集索引(nonclustered index,也称非聚类索引.非簇集索引). SARG的定义:用于限制搜索的一个操作,因为它通常是指一个特定的匹配,一个值得范围内的匹配或者两个以上条件的AND连接.形式如下: 列名 操作符 <常数 或 变量>或<…
原文:SQL开发中容易忽视的一些小地方(四) 本篇我想针对网上一些对于非聚集索引使用场合的某些说法进行一些更正. 下面引用下MSDN对于非聚集索引结构的描述. 非聚集索引结构: 1:非聚集索引与聚集索引具有相同的 B 树结构,它们之间的显著差别在于以下两点:            * 基础表的数据行不按非聚集键的顺序排序和存储.            * 非聚集索引的叶层是由索引页而不是由数据页组成.        2:非聚集索引行中的行定位器或是指向行的指针,或是行的聚集索引键,如下所述:  …
之前已经讲过mysql的性能优化,感兴趣的朋友可以看看之前的文章,<史上最全的MySQL高性能优化实战总结!>.但是有些问题其实是我们自身的SQL语句有问题导致的.今天就来总结哪些经常被我们忽视的SQL错误写法,看看你都踩过哪些坑? 一.LIMIT语句 Limit是分页查询是最常用的场景之一,但也通常也是最容易出问题的地方.比如对于下面简单的语句,一般我们觉得在type, name, create_time字段上加组合索引.这样条件排序都能有效的利用到索引,性能迅速提升. SELECT * F…
一.前言 虽然我们大多数人都学习过SQL,但是经常忽略它.总是会自以为学到的已经足够用了,从而导致我们在实际开发的过程中遇到复杂的问题后只能在检索数据后通过传统的代码来完成,但是其中很多的功能利用SQL就可以轻松的办到,所以我们开始重视SQL,它的地位不亚于C#,javascript. 二.目录 1.多行插入 2.将其他表数据插入 3.子查询 4.通用表表达式(CTE) 5.MERGE指令 6.窗口化函数 7.查询分页 三.正文 1.多行插入 大家都学习过INSERT,但是每次我们都只插入一条数…