文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

T-SQL 高级查询

2024-04-02 19:55

关注

T-SQL高级查询
函数:是一个可反复使用的程序段
从其他的程序段中使用调用语句来执行这段程序
提前写好一段语句,取一个名字,使用时调用这个名字
系统函数:转换数据类型,以及查看系统参数
Convert():数据类型转换为字符串
select converet(varchar(5),12345)
12345 数字 '12345'字符串
CAST():转换数据类型(简单)
select cast('2019-01-18' as datetime) //将字符串转换成时间类
2019-01-18 00:00:00
Current_user():查看当前登入数据库用户名
select current_user
SYSTEM_USER():查看系统的登入用户
select system_user

select '运维工程师'+ 姓名 + '的工资是:'+cast(基本工资 as varchar(50))+'元' from employee where 职务='运维工程师'

字符串函数
CharIndex( )
用来寻找一个指定的字符串在另一个字符串中的起始位置
SELECT CHARINDEX('BDQN','www.bdqn.cn',1)
返回:5
Len( )
返回传递给它的字符串长度
SELECT LEN('SQL Server课程')
返回:12
Upper( )
把传递给它的字符串转换为大写
SELECT UPPER('SQL Server课程')
返回:SQL SERVER课程
Ltrim( )
清除字符左边的空格
SELECT LTRIM (' BDQN ')
返回:BDQN (后面的空格保留)
Rtrim( )
清除字符右边的空格
SELECT RTRIM(' BDQN ')
返回: BDQN前面的空格保留)
Right( )
从字符串右边返回指定数目的字符
SELECT RIGHT('ABCDEFG',3)
返回:EFG
Replace( )
替换一个字符串中的字符
SELECT REPLACE('ABABAB','B','A')
返回:AAAAAA
Stuff( )
在一个字符串中,删除指定位置指定长度的字符串,并在该位置插入一个新的字符串
SELECT STUFF('ABCDEFG',2,3,'我的音乐我的世界')
返回:A我的音乐我的世界EFG
日期函数:
select dateadd(dd,3000,GETDATE()) 当前天数增加3000天 ‘dd天 mm月 yy年’
select datediff(dd,'1998-11-2',getdate()) 求两个日期某段的差
select datename(DW,'2001-05-01') 求日期的星期数
select 姓名,datediff(yy,出生日期,getdate()) AS 年龄 from employee //查看员工年龄(周岁)

聚合函数:
SUM():求和
AVG():求平均值
MAX():求最大值
MIN():最小值
COUNT():非空值的行数
select SUM(基本工资) AS 总工资 from employee
select AVG(基本工资) AS 平均工资,MAX(基本工资) AS 最大,MIN(基本工资) AS 最小 from employee
--统计公司90后有多少人--
select count(出生日期) AS 多少人 from employee where '2000-01-01'>出生日期 and 出生日期>='1990-01-01'

分组查询
select 职务,SUM(基本工资) AS 部门工资 from employee group by 职务
数学函数
Abs( )取数值表达式的绝对值
Ceiling( )取大于或等于指定数值、表达式的最小整数
Floor( )取小于或等于指定表达式的最大整数
Power( )取数值表达式的幂值
Round( )将数值表达式四舍五入为指定 精度
Sign( )对于正数返回+1,对于负数返回-1,对于0则返回0
Sqrt( )取浮点表达式的平方根

综合演练:求公司员工距离30岁还有多少天
select 姓名+'今年'+cast(datediff(yy,出生日期,getdate()) as varchar(10))+'岁'+'距离30岁还有 '+ cast(datediff(dd,getdate(),dateadd(yy,30,出生日期)) as varchar(10))+'天' from employee

内链接:
select A.姓名,A.学校,B.姓名,B.职业 from A INNER JOIN B ON A.姓名=B.姓名

外连接:
左外连接 左表全部显示,右表只显示满足条件的
select A.姓名,A.学校,B.姓名,B.职业 from A LEFT JOIN B ON A.姓名=B.姓名

右外连接 右表全部显示,左表只显示满足条件的
select A.姓名,A.学校,B.姓名,B.职业 from A RIGHT JOIN B ON A.姓名=B.姓名

完全外连接
SELECT A.姓名,A.学校,B.姓名,B.职业 from A FULL JOIN B on A.姓名=B.姓名

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯