2020-08-27

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

 

文章目录

 


前言

随着计算机语言的不断发展,数据库语言这门技术也越来越重要,很多人都开启了数据库语言学习,本文就介绍了数据库语言的基础内容。


提示:以下是本篇文章正文内容,下面案例可供参考

一、数据库是什么?

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管理数据,而转变成用户所需要的各种数据管理的方式。数据库有很多种类型,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。在信息化社会,充分有效地管理和利用各类信息资源,是进行科学研究和决策管理的前提条件。数据库技术管理信息系统、办公自动化系统、决策支持系统等各类信息系统的核心部分,是进行科学研究决策管理的重要技术手段。

二、使用步骤

1.sqlserver基本函数

substring():用于截取指定字符串。该方法有三个参数;

参数1:用于指定要操作的字符串。

参数2:用于指定要截取的字符串的起始位置,起始值为1。

参数3:用于指定截取的长度。

select substring('abcdef',1,3) -- 返回 abc

left():用于返回指定字符串指定长度的左侧部分。该方法有两个参数;

参数1:用于指定要操作的字符串。

参数2:用于指定要返回的字符串的长度。

select LEFT('左侧部分右侧部分',4) -- 返回 左侧部分

Right():用于返回指定字符串指定长度的右侧部分。该方法有两个参数;

参数1:用于指定要操作的字符串。

参数2:用于指定要返回的字符串的长度。

select RIGHT('左侧部分右侧部分',4) -- 返回 右侧部分

CharIndex():用于返回指定字符串指定子字符串出现的起始位置。如果未找到就返回0.该方法有两个参数;

参数1:用于指定要进行查找的字符串。

参数2:用于指定用作检索的字符串。

select charindex('a','123a123') -- 返回 4

Stuff():用于删除指定长度的字符,并在删除的位置插入新的字符/值。该方法有四个参数;

参数1:用于指定要操作的字符串

参数2:用于指定要删除字符的起始位置

参数3:用于指定要删除字符的长度

参数4:用于指定在删除的位置插入新的字符串/值

select stuff('123abc456',4,3,'ABC') -- 返回 123ABC456

len():用于返回指定文本的值的长度。前导空格计算在内,尾随空格不计算在内,该方法有一个参数;

参数1:用于指定要操作的文本或字符串。

select len('123') -- 返回 3

Difference():用于返回一个整数值,指示两个字符串表达式的Soundex值之间的差异。返回的值从0到4不等;0表示几乎不同或完全不同,4表示几乎相同或完全相同。该方法有两个参数;

参数1:用于指定要进行比较的第一个字符串soundex值

参数2:用于指定要进行对比的第二个字符串soundex值

select difference('action','demo') -- 返回 2

Soundex():用于返回指定字符串的soundex值。soundex是一种语音算法,利用英文字的读音计算近似值,值由四个字符构成,第一个字符为英文字母,后三个为数字。在拼音中有时会出现念但不能拼出正确子的情形,可用soundex做类似的模糊匹配效果。这里的模糊匹配和like不同。如果字符串中存在拥有相同对应数字的2个或以上的字母在一起(例如j,k),则删除其他的,只保留1个。去除对应值为0的字符,只返回前4个字节,不够用0填充。除了英文字符以外的字符都将返回0000.

-- 将英文字按以下规则替换(不使用第一个字符进行匹配,并且不使用对应值为 0 的英文字符的值) a e h i o u w y -> 0 b f p v -> 1 c g j k q s x z -> 2 d t -> 3 l -> 4 m n -> 5 r -> 6

select soundex('string') -- 返回 S215

lower():用于返回指定英文字符的小写形式的字符串。如果不为英文字符串,则返回原值。该方法有一个参数:

参数1:用于指定要转换为小写形式的字符串。

select lower('ABC') -- 返回 abc

Upper():用于返回指定英文字符串的大写形式的字符串。如果不为英文字符串,则返回原值。该方法有一个参数;

参数1:用于指定要转换为大写形式的字符串。

select upper('abc') -- 返回 ABC

Ltrim():用于返回删除前导空格之后的字符串,该方法有一个参数;

参数1:用于指定要进行删除前导空格操作的字符串。

select ltrim(' 123') -- 返回 123

Rtrim():用于删除截断尾随空格之后的字符串。该方法有一个参数;

参数1:用于指定要进行截断尾随空格操作的字符串。

select rtrim('123 ') -- 返回 123

Replace():用于第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。该方法有三个参数;

参数1:用于指定要操作的字符串,即被匹配的字符串。

参数2:用于指定要进行匹配的字符串。

参数3:用于指定用作替换存在的匹配项的字符串。

--把 abc 替换为 xxx select replace('123abc456','abc','xxx') -- 返回 123xxx456

Unicode():根据Unicode标准返回指定字符或字符串的第一个字符的整数值。该方法有个参数;

参数1:用于指定要操作的字符或字符串。

select unicode('a') -- 返回 97 select unicode('abc') -- 返回 97,只返回第一个字符

Nchar():根据nuicode()标准返回指定整数值代码的Unicode字符。该方法有一个参数;

参数1:指定一个Unicode()标准的整数值代码

select nchar(97) -- 返回 a select nchar(65) -- 返回 A

Char():将指定的int类型的值转换成ASCII代码,该方法有一个参数;

参数1:指定一个int类型的数值,值范围为0-255.返回null表示整数表达式不在此范围。

select char(99) -- 返回 c select char(9) -- Tab符 select char(10) -- 换行符 select char(13) -- 回车符

ASCII():返回指定字符或字符串的第一个字符的ASCII代码值。该方法有一个参数;

参数1:用于指定要操作的字符或字符串。

select ascii('A') -- 返回 65 select ascii('a') -- 返回 97

Str():返回一个指定数值的等效字符串。该方法有三个参数;

参数1:指定要操作的数值,

参数2:指定要返回字符串的长度,默认值为10,即不指定默认长度为10,不足用空字符填充。

参数3:要返回的小数位数,默认值为0,即不指定就不保留小数,不足则指定位数,用0补充。

select str(123.10) -- 返回 123 select len(str(123.10)) -- 返回 10 select str(123.10,5) -- 返回 123 select len(str(123.10,5)) -- 返回 5 select str(123.10,20,5) -- 返回 123.10000 select len(str(123.10,20,5)) -- 返回 20

space():用于返回值指定值长度的空格字符串。该方法有一个参数;

参数1:指定返回空格字符串的长度。

select '1'+space(3)+'2' -- 返回 1 2 select len('1'+space(3)+'2') -- 返回 5

Reverse():用于对指定字符串进行反转,按照单个字符进行反转,该方法有个参数;

参数1:指定要执行反转操作的字符串。

select reverse('123') -- 返回 321 select reverse('abc') -- 返回 cba

Replicate():用于返回一个指定字符串重复指定次数后的字符串。该方法有两个参数;

参数1:用于指定要操作的字符串;

参数2:用于指定字符串重复的次数,如果为0,返回空字符串;如果为负数,则返回null

select replicate('123',3) -- 返回 123123123 select replicate('a',3) -- 返回 aaa

Quotename():返回一个Unicode字符串,根据指定分隔符,返回一个有效的字符串标识符,该方法有两个参数;

参数1:用于指定要操作的字符

参数2:用于指定分隔符,可以是单引号(')、左括号([)、右括号(])、左右括号([])或双引号(").如果未指定,默认使用左右括号。

select quotename('123','[]') -- 返回 [123] select quotename('123','''') -- 返回 '123' select quotename('123','"') -- 返回 "123" select quotename('12[]3','[]') -- 返回 [12[]]3],右括号加倍表示转义字符。

Patindex():返回指定字符串中指定模式第一次出现的起始位置,未找到则返回0,该方法有两个参数;

参数1:指定要匹配的字符串以及匹配模式;

参数2:指定要被匹配的字符串表达式

select Patindex('abc','123abc456abc789') -- 返回 0 select Patindex('abc','abc') -- 返回 1 select Patindex('abc%','123abc456abc789') -- 返回 0 select Patindex('%abc%','123abc456abc789') -- 返回 4 select Patindex('%[abc]%','123abc456abc789') -- 匹配字符串 abc 第一次出现的位置,返回 4 select Patindex('%[^abc]%','123abc456abc789') -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 1 select Patindex('%[^abc]%','b123abc456abc789') -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 2

Datepart():返回指定日期的指定日期的部分整数.Datepart()方法和Datename()的方法使用方法类似,只不过Datename()方法返回的是一个字符串。

参数1:指定返回指定日期的指定部分的字符串

参数2:指定要操作的日期字符串。

select datepart(year,'2017-01-01 10:10:10') -- 返回 2017 select datepart(yyyy,'2017-01-01 10:10:10') -- 返回 2017 select datepart(month,'2017-01-01 10:10:10') -- 返回 1 select datepart(mm,'2017-01-01 10:10:10') -- 返回 1 select datepart(quarter,'2017-05-02 10:10:10') -- 表示一年的第几个季度 返回 2 select datepart(weekday,'2017-02-02 10:10:10') -- 表示一周的星期几,即一周的第几天,星期日为一周的第一天 返回 5 select datepart(week,'2017-02-02 10:10:10') -- 表示一年的第几周 返回 5 select datepart(dayofyear,'2017-02-02 10:10:10') -- 表示一年的第几天 返回 33 select datepart(hh,'2017-01-01 10:30:25') -- 返回 10

 


总结

以上就是今天要讲的内容,本文仅仅简单介绍了sqlserver基本函数的使用,而sqlserver提供了大量能使我们快速便捷地处理数据的函数和方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值