技术经验解读:【读书笔记】SQL语言基础

简介: 技术经验解读:【读书笔记】SQL语言基础

----------------SQL语言基础-----------------:摘自《Oracle + 11g + 从入门到精通》


1.SQL的主要功能


1)数据定义功能(DDL)


2)数据查询功能(DQL)


3)数据操纵功能(Data Manipulation Lauguage,DML)


4)数据控制功能(DCL)


2.语句编写规则


1)关键字、对象名和列名不区分大小写


2)字符值和日期值区分大小写


3.数据定义


1)创建表


CREATE


TABLE [/span>表名

(


[/span>列名数据类型

【列级完整性约束条件】


【,[/span>列名数据类型

【列级完整性约束条件】】


...


【,[/span>表级完整性约束条件

);


2)创建视图:虚表,只存放视图的定义,不存放视图对应的数据


CREATE


VIEW [/span>视图名列名列名

AS


[/span>子查询

【WITH


CHECK OPTION】 --表示对视图进行UPDATE、INSERT和DELETE操作时,要保证更新、插入或删除的行满足视图定义中的谓词条件(即子查询中的条件表达式)


3)创建索引


CREATE


【UNIQUE】 【CLUSTER】 INDEX [/span>索引名

ON


[/span>表名列名次序列名次序

4)删除表


DROP


TABLE [/span>表名

--删除表后,数据,索引会删除,但是视图定义不会


5)删除视图


DROP


VIEW [/span>视图名

6)删除索引


DROP


INDEX [/span>索引名

7)修改建立好的基表,SQL语言中,没有提供删除属性列的语句


ALTER


TABLE [/span>表名

【ADD


,[/span>新列名数据类型

【完整性约束】】


【DROP


[/span>完整性约束名

【MODIFY


[/span>列名数据类型

4.数据查询


SELECT


【ALL|DISTINCT】 TOP n【PERCENT】 WITH TIES select_list


【INTO


【 new table name】】



FROM


{table_name|view_name}【(optimizer_hints)】


【,{table_name2|view_name2}【(optimizer_hints)】】


【...{table_name2|view_name2}【(optimizerhints)】】



【WHERE


clause】


【GROUP


BY clause】


【HAVING


clause】


【ORDER


BY clause】


【COMPUTE


clause】


【FOR


BROWSE】


1)LIKE表达式中,通配符'%'代表0个、1个或多个任意字符,''代表一个任意字符。


2)使用GROUP


BY需要满足的条件


a.


在SELECT子句的后面只可以有两类表达式:统计函数和进行分组的列名


b.


在SELECT子句中的列名必须是进行分组的列,除此之外添加其他的列名都是错误的,但是,


GROUP


by子句后面的列名可以不出现在select子句中


c.如果使用了where子句,那么所有参加分组计算的数据必须首先满足where子句指定的条件


d.默认情况下,将按照GROUP


BY子句指定的分组列升序排序,如果需要重新排序,可以使用ORDER


BY子句指定新的排列顺序。


3)HAVING子句对GROUP


BY分组的结//代码效果参考:http://www.jhylw.com.cn/582120001.html

果做进一步的筛选。

4)多表连接查询


逗号连接,JOIN连接


FROM join_table1 join_type join_table2


【ON(join_condition)】


join_type:


a.内连接(INNER


JOIN)可省略INNER),使用ON指定连接表的连接条件,可以用于多表


b.自然连接(natural


join):Oracle会将第一个表中的那些列与第二个表中具有相同名称的列进行连接,实际中应用较少


c.外连接(LEFT


OUTER JOIN 或 LEFT JOIN;


RIGHT OUTER JOIN或RIGHT


JOIN;FULL OUTER


JOIN或FULL JOIN)


与内连接不同的是,外连接不只列出与连接条件相匹配(on)的行,还列出左表(左外连接时)、右表(右外连接时)


或两个表(全外连接时)中所有符合搜索条件(WHERE,HAVING)的数据行。


在执行完全外连接时,系统开销很大,因为Oracle实际上会执行一个完整的左连接查询和右连接查询,然后再将其结果集合并,并消除重复的记录行。


d.自连接:自引用式外键意味着表中的一个列可以是该表主键的一个外键。例如,EMPLOYEES表的MANAGER_ID列可以是另一行的EMPLOYEE_ID


select


em1.last_name "manager",em2.last_name "employee"


from


employees em1 left join employees em2


on


em1.employee_id = em2.manager_id


order


by em1.employee_id


5)集合操作


UNION,UNION


ALL, INTERSECT,MINUS


UNION运算会将合集中的重复记录滤除,这是UNION运算和UNION


ALL 运算唯一不同的地方。


6)子查询


是一个select语句,可以在select、insert、update或delete语句中使用。虽然大部分子查询是在select语句的where子句中实现,但实际上


它的应用不仅仅局限于此。例如,可以在SELECT和HAVING子句中使用


a.IN关键字:


where column_name in (select...)


b.EXISTS关键字:where


exists(select * from...),只考虑是否满足判断条件,不考虑数据内容,返回TRUE


OR FALSE


c.比较运算符:适用于子查询返回结果只包含一个值。

5.数据操纵


1)一般INSERT语句


INSERT


INTO 【user.】table 【@db_link】【(column1 【,column2】...)】


VALUES(express1【,express2】...)


使用desc


table_name 命令查看表中各列的定义次序。


2)批量INSERT语句


INSERT


INTO 【user.】table 【@db_link】【(column1 【,column2】...)】 Subquery


INSERT


INTO指定的列名可以与SELECT指定的列名不同,但是其数据类型必须相匹配,即SELECT返回的数据必须满足表中列的约束


3)UPDATE语句


UPDATE


table_name


SET


{column1 = express1【,column2 = express2】,


column1【,column2】


= (select query)}


【WHERE


condition】


4)DELETE语句


DELETE


FROM table_name


【WHERE


condition】


5)TRUNCATE语句


删除表中所有的记录,速度要比DELETE语句快,因为它不会产生回滚信息,不能被撤销。


TRUNCATE


TABLE TABLE_NAME


6.数据控制


事务管理功能和数据保护功能


1)GRANT


语句


GRANT


[/span>权限权限

【ON[/span>对象类型对象名

TO[/span>用户用户

【WITH


GRANT OPTION】


对于不同类型的操作对象有不同的操作权限,对属性列和视图的操作包括SELECT/INSERT/UPDATE/DELETE/ALLPRIVILEGES。


对基表的操作包括SELECT/INSERT/UPDATE/DELETE/ALTER/INDEX/ALLPRIVILEGES


对数据库可以有建立表(CREATETAB)的权限


例:


GRANT


SELECT ON TABLE DEPARTMENT TO User2,User3


GRANT


UPDATE(EMPLOYEE_ID),SELECT ON TABLE IT_EMPLOYEES TO User4;


2)REVOKE语句:收回权限的操作会级联下去


REVOKE


[/span>权限权限

【ON[/span>对象类型对象名

FROM[/span>用户用户

7.Oracle常用函数


1)字符类函数


ASCII()


返回c1中第一个字母的ASCII码,c1是字符串


CHR() 求i对应的ASCII字符


CONCAT(C1,C2)


将C2连接到C1后面,和||操作符效果一样


INITCAP(C1),将C1中每个单词的第一个字母大写,其他字母小写返回。单词由空格、控制字符、标点符号限制


INTSTR(C1,【C2,【,j】】)


返回c2在c1中第j次出现的位置,搜索从c1的第i个字符开始。当没有发现需要的字符时


返回0,如果i为负数,搜索将从右到做进行,但是位置还是从左到右来计算,i和j默认值为1


INSTRB(C1,【C2,【,j】】)


与INSTR()函数一样,只是其返回的是字节,对于单字节INSTRB()等于INSTR()。


LENGTH(C1)


该函数用于返回c1的长度,如果c1为null,那么将返回NULL值


lower(c1)


该函数用于返回c1的小写字符,经常出现在where子串中。


LTRIM(c1,c2)


将c1中最左边的字符去掉,使其第一个字符不在c2中,如果没有c2,那么c1就不会改变。


REPLACE(C1,C2【,C3】)


用c3代替出现在c1中的c2后返回,其中c1,c2,c3都是字符串


SUBSTR(C1,【,j】)


从c1的第i位开始返回长度为j的子字符串,如果j为空,则直到串的尾部。


TRIM(c1)用于将c1的前后空格删除


2)数字类函数


ABS(n),ACOS(n),ASIN(n),ATAN(n),CEIL(n),COS(n),COSH(n),EXP(n),FLOOR(n),LN(n),LOG(n1,n2),MOD(n1,n2),POWER(N1,N2)


ROUND(n1,n2)【四舍五入】,


SIGN(n)【返回-1,0,1】,SIN(n),SINH(n),SQRT(n),TAN(n),TANH(n),TRUNC(n1,n2)【截尾】


3)日期类函数


ADD_MONTHS(d,)


LAST_DAY(d) MONTHS_BETWEEN(d1,d2) NEW_TIME(d1,tz1,tz2) SYSDATE


4)转换类函数


CHARTORWID(c1)


CONVERT(c1,dset【,sset】)


ROWIDTOCHAR()


TO_CHAR(x【,fmt【nlsparm,】】)


TO_DATE(c1【,fmt【nlsparm,】】)


TO_MULTI_BYTE(c1)


TO_NUMBER(c1【,fmt【nlsparm,】】)


TO_SINGLE_BYTE(c1)


5)聚集类函数,返回基于多个行的单一结果


AVG(x【{DISTINCT|ALL}】)


COUNT(x【{DISTINCT|ALL}】)


MAX(x【{DISTINCT|ALL}】)


MIN(x【{DISTINCT|ALL}】)


STDDEV(x【{DISTINCT|ALL}】)


--标准差


SUM(x【{DISTINCT|ALL}】)


VARIANCE(x【{DISTINCT|ALL}】) --方差

相关文章
|
2月前
|
SQL 存储 算法
比 SQL 快出数量级的大数据计算技术
SQL 是大数据计算中最常用的工具,但在实际应用中,SQL 经常跑得很慢,浪费大量硬件资源。例如,某银行的反洗钱计算在 11 节点的 Vertica 集群上跑了 1.5 小时,而用 SPL 重写后,单机只需 26 秒。类似地,电商漏斗运算和时空碰撞任务在使用 SPL 后,性能也大幅提升。这是因为 SQL 无法写出低复杂度的算法,而 SPL 提供了更强大的数据类型和基础运算,能够实现高效计算。
|
3月前
|
SQL Oracle 关系型数据库
SQL语言的主要标准及其应用技巧
SQL(Structured Query Language)是数据库领域的标准语言,广泛应用于各种数据库管理系统(DBMS)中,如MySQL、Oracle、SQL Server等
|
3月前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
107 11
|
3月前
|
SQL 安全 数据库
sql注入技术
sql注入技术
|
4月前
|
SQL 机器学习/深度学习 自然语言处理
Text-to-SQL技术演进 - 阿里云OpenSearch-SQL在BIRD榜单夺冠方法剖析
本文主要介绍了阿里云OpenSearch在Text-to-SQL任务中的最新进展和技术细节。
|
4月前
|
SQL 安全 数据库
基于SQL Server事务日志的数据库恢复技术及实战代码详解
基于事务日志的数据库恢复技术是SQL Server中一个非常强大的功能,它能够帮助数据库管理员在数据丢失或损坏的情况下,有效地恢复数据。通过定期备份数据库和事务日志,并在需要时按照正确的步骤恢复,可以最大限度地减少数据丢失的风险。需要注意的是,恢复数据是一个需要谨慎操作的过程,建议在执行恢复操作之前,详细了解相关的操作步骤和注意事项,以确保数据的安全和完整。
185 0
|
5月前
|
SQL 关系型数据库 MySQL
|
5月前
|
测试技术 Java
揭秘Struts 2测试的秘密:如何打造无懈可击的Web应用?
【8月更文挑战第31天】在软件开发中,确保代码质量的关键在于全面测试。对于基于Struts 2框架的应用,结合单元测试与集成测试是一种有效的策略。单元测试聚焦于独立组件的功能验证,如Action类的执行逻辑;而集成测试则关注组件间的交互,确保框架各部分协同工作。使用JUnit进行单元测试,可通过简单示例验证Action类的返回值;利用Struts 2 Testing插件进行集成测试,则可模拟HTTP请求,确保Action方法正确处理请求并返回预期结果。这种结合测试的方法不仅提高了代码质量和可靠性,还保证了系统各部分按需协作。
31 0
|
5月前
|
SQL 数据挖掘 数据库
SQL中的重复行删除:技术与策略
【8月更文挑战第31天】
145 0
|
5月前
|
SQL 数据管理 关系型数据库
SQL分区表技术的奥秘:如何用分区策略让你的大规模数据飞起来?
【8月更文挑战第31天】在现代软件开发中,处理大规模数据是常见挑战,而SQL分区表技术提供了一种高效的解决方案。本文详细介绍了SQL分区表的概念、类型(范围、列表、哈希和键分区)及其创建与维护方法,并通过示例代码展示了如何添加、删除和重组分区。遵循了解查询模式、定期维护分区及使用数据库性能工具等最佳实践,可以帮助开发者更高效地进行数据管理。随着SQL生态的发展,分区表技术将在未来发挥更大作用。
53 0