分享
 
 
 

实战SQL语句收集(不断更新中--)

王朝mssql·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

实战SQL语句收集(不断更新中--)

前言:这里将我编程实践中遇到的有价值的sql语句一路记下来,一方面方便自己查用,一方面也夯实下即将遗忘的回忆。整个过程中我会不断更新,直到不能再加为止,同时,这里只记录最实用的咚咚,不效仿学院派的那一套。

一、常用SQL语句荟萃

1,查询:

1.1,简单查询:select * from table where

1.2,连接查询:

什么是连接查询?顾名释义,就是查询时涉及多个表的查询。是以说到连接,废话一下,要知道连接还是关系数据库的主要特点呢。

连接查询分为三种:外连接(OUTER JOIN),内连接(INNER JOIN),交叉连接(CROSS JOIN)。

1.2.1,内连接(INNER JOIN)使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。

1.2.2,外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN)和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。

1.2.3,交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。

1.2.4,无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接连接。例如:

SELECT p1.pub_id,p2.pub_id,p1.pr_info

FROM pub_info AS p1 INNER JOIN pub_info AS p2

ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)

1.2.5,使用WHERE子句设置查询条件

WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据:

SELECT *

FROM usertable

WHERE age>20

WHERE子句可包括各种条件运算符:

比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!<

范围运算符(表达式值是否在指定的范围):BETWEEN…AND…

NOT BETWEEN…AND…

列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……)

NOT IN (项1,项2……)

模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE

空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL

逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR

1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30

2、列表运算符例:country IN ('Germany','China')

3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、varchar、text、ntext、datetime和smalldatetime等类型查询。

可使用以下通配字符:

百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。

下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。

方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。

[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。

例如:

限制以Publishing结尾,使用LIKE '%Publishing'

限制以A开头:LIKE '[A]%'

限制以A开头外:LIKE '[^A]%'

空值判断符例:WHERE age IS NULL

2,更新:update table

3,插入:

3.1,一般插入:

INSERT INTO publishers

(pub_id, pub_name, city, state)

VALUES

('9001', 'Acme Publishing', 'New York', 'NY')

3.2,插入多行

使用 INSERT 语句可以向表添加多行数据。这些多行数据是从已经存有这些数据的另一个表中选取的。本例中,向 pubhold 表中添加有关在加利福尼亚和德克萨斯州的出版商的数据。这些数据可从 publishers 表中获得。

INSERT pubhpold SELECT * FROM publishers

WHERE state = 'CA' OR state = 'TX'

4,删除:

4.1,Delete语句联合删除:

DELETE FROM uu_SuiteToMinClassroomSect

WHERE min_classroom_sect_id IN

(SELECT min_classroom_sect_id

FROM uu_MinClassroomSect

WHERE min_classroom_id = '112')

二、视图使用细则

1,一个典型的视图

CREATE VIEW View_uuGroupTaxis

AS

SELECT uu_GroupInfo.group_id, uu_GroupInfo.group_name,

uu_GroupType.main_type, uu_GroupType.group_type_name,

uu_GroupInfo.group_icon_url, ISNULL

((SELECT COUNT(*)

FROM uu_GroupUser

WHERE uu_GroupInfo.group_id = uu_GroupUser.group_id), 0)

* 50 + ISNULL(uu_GroupInfo.fundCount, 0) + ISNULL

((SELECT COUNT(*)

FROM Dv_Topic

WHERE Dv_Topic.BoardID = uu_GroupInfo.subforum_id), 0) * 5 + ISNULL

((SELECT COUNT(*)

FROM uu_GroupPhotos

WHERE uu_GroupPhotos.group_id = uu_GroupInfo.group_id), 0)

* 10 + ISNULL(uu_GroupInfo.topic_account, 0)

* 2 + ISNULL(uu_GroupInfo.hit_account, 0) AS group_ActiveDegree,

ISNULL

((SELECT COUNT(*)

FROM uu_GroupUser

WHERE uu_GroupInfo.group_id = uu_GroupUser.group_id), 0)

AS group_memberNum, ISNULL(uu_GroupInfo.fundCount, 0) AS fundCount,

(SELECT COUNT(*)

FROM Dv_Topic

WHERE Dv_Topic.BoardID = uu_GroupInfo.subforum_id) AS group_articleNum,

(SELECT COUNT(*)

FROM uu_GroupPhotos

WHERE uu_GroupPhotos.group_id = uu_GroupInfo.group_id) AS group_PhotoNum,

uu_GroupInfo.topic_account, uu_GroupInfo.hit_account,

(SELECT user_name

FROM uu_RegisterUser

WHERE uu_RegisterUser.user_id = uu_GroupInfo.creator_id)

AS group_CreatorName, uu_GroupInfo.create_time

FROM uu_GroupInfo INNER JOIN

uu_GroupType ON

uu_GroupInfo.group_type_id = uu_GroupType.group_type_id

三,存储过程的创建和调用

1,存储过程的调用

Execute procedureName @param=’value’

2,一个典型的带参数存储过程

CREATE PROCEDURE P_delMiniclassProc

@miniClassroom_id int

AS

declare @billtag varchar(4)

set nocount on

IF @miniClassroom_id is null

begin

return(-1)

end

else

BEGIN TRANSACTION

--删除套餐信息

DELETE FROM uu_SuiteToMinClassroomSect

WHERE min_classroom_sect_id IN

(SELECT min_classroom_sect_id

FROM uu_MinClassroomSect

WHERE min_classroom_id =@miniClassroom_id)

--删除小课堂段信息

delete from uu_MinClassroomSect

where min_classroom_id = @miniClassroom_id

--删除小课堂用户购买记录

delete from uu_UserBuyMinClassroom

where min_classroom_id = @miniClassroom_id

--删除对应小课堂年级学科信息

delete from uu_MinClassroomToGradeClass

where min_classroom_id = @miniClassroom_id

--删除小课堂发言

delete from uu_MinClassroomDiscuss

where min_classroom_id = @miniClassroom_id

--删除课程讨论

DELETE FROM uu_CourseDiscuss

WHERE course_id IN

(SELECT course_id

FROM uu_CourseInfo

WHERE min_classroom_id = @miniClassroom_id)

--删除用户课程收藏

DELETE FROM uu_UserCellectionCourse

WHERE course_id IN

(SELECT course_id

FROM uu_CourseInfo

WHERE min_classroom_id = @miniClassroom_id)

--删除小课堂小课程的用户购买信息

DELETE FROM uu_UserBuyCourse

WHERE course_id IN

(SELECT course_id

FROM uu_CourseInfo

WHERE min_classroom_id = @miniClassroom_id)

commit TRANSACTION

return(1)

GO

四,触发器

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有