数据库常用函数
数据库常用函数汇总统计
实验二(续):利用SQL语句查询三、常用库函数及统计汇总查询1、求学号为 S1学生的总分和平均分;select sum(score) as TotalScore,avg(score)as AveScorefrom scwhere sno='S1'2、求选修 C1号课程的最高分、最低分及之间相差的分数;select max(score)as MaxScore,min(score)as MinScore, max(score)- min(score)as difffrom scwhere cno='C1'3、求选修 C1号课程的学生人数和最高分;select count(distinct sno),max(score)from scwhere cno='C 1'4、求计算机系学生的总数;select count(sno)from swhere dept=' 计算机 '5、求学校中共有多少个系;select count(distinct dept) as DeptNumfrom s6、统计有成绩同学的人数;select count(score)from sc7、利用特殊函数 COUNT(*)求计算机系学生的总数;select count(*)from swhere dept=' 计算机 '8、利用特殊函数 COUNT(*)求女学生总数和平均年龄;select count(*),avg(age)from swhere sex=' 女 '9、利用特殊函数 COUNT(*)求计算机系女教师的总数。
select count(*)from twhere dept=' 计算机 'and sex=' 女 '四、分组查询及排序1、查询各个教师的教师号及其任课门数;select tno,count(*)as c_numfrom tcgroup by tno2、按系统计女教师的人数;select dept,count(tno)from twhere sex=' 女 'group by dept3、查询选修两门以上课程的学生的学号和选课门数;select sno,count(*)as sc_numfrom scgroup by snohaving count(*)>24、查询平均成绩大于 70分的课程号和平均成绩;select cno,avg(score)from scgroup by cnohaving avg(score)>705、查询选修 C1的学生学号和成绩,并按成绩降序排列;select sno,scorefrom scwhere cno='01'order by score desc6、查询选修 C2、C3、C4或C5课程的学号、课程号和成绩,查询结果按学号升序排列,学号相同再按成绩降序排列;select sno,cno,scorefrom scwhere cno in('C2','C3','C4','C5')order by sno ,score desc7、求有三门以上选课成绩及格的学生的学号及其总成绩,查询结果按总成绩降序列出。
数据库count函数的用法
数据库count函数的用法COUNT 函数是SQL 中常用的一个聚合函数,用于计算表中的行数或特定列中的非空值数量。
以下是 COUNT 函数的基本用法和一些示例:基本语法sql复制代码SELECTCOUNT(column_name)FROM table_nameWHERE condition;示例1.计算表中的总行数:sql复制代码SELECT COUNT(*) FROMstudents;这将返回 students 表中的总行数。
2. 计算特定列的非空值数量:sql复制代码SELECT COUNT(name) FROMstudents;这将返回 students 表中 name 列的非空值数量。
3. 计算满足特定条件的行数:sql复制代码SELECT COUNT(*) FROM students WHEREage > 20;这将返回 students 表中年龄大于20 的学生数量。
4. 计算多列的组合非空值数量:sql复制代码SELECT COUNT(DISTINCT name, age) FROM students;这将返回 students 表中不同 name 和 age 组合的数量。
注意事项•COUNT(*) 计算表中的总行数,包括所有列都为空的行。
•COUNT(column_name) 计算特定列的非空值数量。
如果列值为NULL,则不计入总数。
•COUNT(DISTINCT column_name) 计算特定列的唯一非空值数量。
•使用 WHERE 子句可以限制计数范围,只计算满足特定条件的行。
这些只是 COUNT 函数的基本用法。
在实际应用中,你可以根据具体需求灵活使用 COUNT 函数来处理数据。
数据库聚集函数
数据库聚集函数数据库聚集函数是数据库中常用的一种函数,它用于统计数据表中某一列的数据信息。
本文将介绍常用的数据库聚集函数及其用法。
1. COUNT函数COUNT函数是最常用的聚集函数之一,它用于计算数据表中某一列的记录数。
语法如下:COUNT(column_name)其中,column_name是要统计记录数的列名。
如果不指定列名,则统计整个数据表的记录数。
COUNT函数返回值为一个整数,表示记录数。
2. SUM函数SUM函数用于计算数据表中某一列的数值总和。
语法如下:SUM(column_name)其中,column_name是要计算总和的列名。
SUM函数返回值为一个数值,表示总和。
3. AVG函数AVG函数用于计算数据表中某一列的数值平均值。
语法如下:AVG(column_name)其中,column_name是要计算平均值的列名。
AVG函数返回值为一个数值,表示平均值。
4. MAX函数MAX函数用于计算数据表中某一列的最大值。
语法如下:MAX(column_name)其中,column_name是要计算最大值的列名。
MAX函数返回值为一个数值,表示最大值。
5. MIN函数MIN函数用于计算数据表中某一列的最小值。
语法如下:MIN(column_name)其中,column_name是要计算最小值的列名。
MIN函数返回值为一个数值,表示最小值。
除了以上五种常用的聚集函数外,还有一些其他的聚集函数,例如:6. VARIANCE函数VARIANCE函数用于计算数据表中某一列的方差。
语法如下:VARIANCE(column_name)其中,column_name是要计算方差的列名。
VARIANCE函数返回值为一个数值,表示方差。
7. STDDEV函数STDDEV函数用于计算数据表中某一列的标准差。
语法如下:STDDEV(column_name)其中,column_name是要计算标准差的列名。
STDDEV函数返回值为一个数值,表示标准差。
Excel的14个常用的数据库函数
Excel的14个常用的数据库函数1. DVARP函数:用于计算总体方差。
语法:DVARP(database,field,criteria)参数:database表示要在其中计算方差的数据范围,field表示要计算方差的字段,criteria 是一个可选的筛选条件。
2. GETPOVOTDATA函数:用于从数据透视表中获取特定单元格的值。
语法:GETPOVOTDATA(data_field, pivot_table, [field1, item1], [field2, item2], …)参数:data_field表示从数据透视表中返回的数据区域,pivot_table表示要检索数据的数据透视表,field1, item1等表示要使用的筛选条件。
3. DVAR函数:用于计算样本方差。
语法:DVAR(database,field,criteria)参数:database表示要在其中计算方差的数据范围,field表示要计算方差的字段,criteria 是一个可选的筛选条件。
4. DSTDEVP函数:用于计算总体标准差。
语法:DSTDEVP(database,field,criteria)参数:database表示要在其中计算标准差的数据范围,field表示要计算标准差的字段,criteria是一个可选的筛选条件。
5. DSUM函数:用于计算数据范围中数值的总和。
语法:DSUM(database,field,criteria)参数:database表示要在其中计算总和的数据范围,field表示要计算的字段,criteria 是一个可选的筛选条件。
6. DPRODUCT函数:用于计算数据范围中数值的乘积。
语法:DPRODUCT(database,field,criteria)参数:database表示要在其中计算乘积的数据范围,field表示要计算的字段,criteria 是一个可选的筛选条件。
7. DSTDEV函数:用于计算样本标准差。
mysql常用的聚合函数
mysql常用的聚合函数MySQL是一种常用的关系型数据库管理系统,它提供了许多强大的聚合函数,用于统计和计算数据。
在本文中,我们将介绍一些常用的MySQL聚合函数,并探讨它们的用法和作用。
一、COUNT函数COUNT函数用于统计某个列或表中的行数。
它可以用来计算表中的记录数量,或者根据条件统计满足条件的记录数量。
例如,我们可以使用以下语句统计一个表中的记录数量:SELECT COUNT(*) FROM table_name;二、SUM函数SUM函数用于计算某个列的总和。
它可以用于计算数值型数据的总和,比如销售额、订单数量等。
例如,我们可以使用以下语句计算一个表中某个列的总和:SELECT SUM(column_name) FROM table_name;三、AVG函数AVG函数用于计算某个列的平均值。
它可以用于计算数值型数据的平均值,比如平均销售额、平均订单数量等。
例如,我们可以使用以下语句计算一个表中某个列的平均值:SELECT AVG(column_name) FROM table_name;四、MAX函数MAX函数用于找出某个列的最大值。
它可以用于寻找数值型数据中的最大值,或者日期型数据中的最晚日期。
例如,我们可以使用以下语句找出一个表中某个列的最大值:SELECT MAX(column_name) FROM table_name;五、MIN函数MIN函数用于找出某个列的最小值。
它可以用于寻找数值型数据中的最小值,或者日期型数据中的最早日期。
例如,我们可以使用以下语句找出一个表中某个列的最小值:SELECT MIN(column_name) FROM table_name;六、GROUP BY子句GROUP BY子句用于根据某个列对结果进行分组。
它可以将相同值的行分为一组,并进行聚合计算。
例如,我们可以使用以下语句根据某个列对表中的数据进行分组,并计算每组的平均值:SELECT column_name, AVG(column_name) FROM table_name GROUP BY column_name;七、HAVING子句HAVING子句用于过滤分组后的结果。
数据库常用函数
数据库常⽤函数⼀、数学函数abs(x) 返回x的绝对值bin(x) 返回x的⼆进制(oct返回⼋进制,hex返回⼗六进制)ceiling(x) 返回⼤于x的最⼩整数值exp(x) 返回值e(⾃然对数的底)的x次⽅floor(x) 返回⼩于x的最⼤整数值greatest(x1,x2,...,xn)返回集合中最⼤的值least(x1,x2,...,xn) 返回集合中最⼩的值ln(x) 返回x的⾃然对数log(x,y)返回x的以y为底的对数mod(x,y) 返回x/y的模(余数)pi()返回pi的值(圆周率)rand()返回0到1内的随机值,可以通过提供⼀个参数(种⼦)使rand()随机数⽣成器⽣成⼀个指定的值。
round(x,y)返回参数x的四舍五⼊的有y位⼩数的值sign(x) 返回代表数字x的符号的值sqrt(x) 返回⼀个数的平⽅根truncate(x,y) 返回数字x截短为y位⼩数的结果⼆、聚合函数(常⽤于group by从句的select查询中)avg(col)返回指定列的平均值count(col)返回指定列中⾮null值的个数min(col)返回指定列的最⼩值max(col)返回指定列的最⼤值sum(col)返回指定列的所有值之和group_concat(col) 返回由属于⼀组的列值连接组合⽽成的结果三、字符串函数ascii(char)返回字符的ascii码值bit_length(str)返回字符串的⽐特长度concat(s1,s2...,sn)将s1,s2...,sn连接成字符串concat_ws(sep,s1,s2...,sn)将s1,s2...,sn连接成字符串,并⽤sep字符间隔insert(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的⼦串替换为字符串instr,返回结果find_in_set(str,list)分析逗号分隔的list列表,如果发现str,返回str在list中的位置lcase(str)或lower(str) 返回将字符串str中所有字符改变为⼩写后的结果left(str,x)返回字符串str中最左边的x个字符length(s)返回字符串str中的字符数ltrim(str) 从字符串str中切掉开头的空格position(substr in str) 返回⼦串substr在字符串str中第⼀次出现的位置quote(str) ⽤反斜杠转义str中的单引号repeat(str,srchstr,rplcstr)返回字符串str重复x次的结果reverse(str) 返回颠倒字符串str的结果right(str,x) 返回字符串str中最右边的x个字符rtrim(str) 返回字符串str尾部的空格strcmp(s1,s2)⽐较字符串s1和s2trim(str)去除字符串⾸部和尾部的所有空格ucase(str)或upper(str) 返回将字符串str中所有字符转变为⼤写后的结果四、⽇期和时间函数curdate()或current_date() 返回当前的⽇期curtime()或current_time() 返回当前的时间date_add(date,interval int keyword)返回⽇期date加上间隔时间int的结果(int必须按照关键字进⾏格式化),如:selectdate_add(current_date,interval 6 month);date_format(date,fmt) 依照指定的fmt格式格式化⽇期date值date_sub(date,interval int keyword)返回⽇期date加上间隔时间int的结果(int必须按照关键字进⾏格式化),如:selectdate_sub(current_date,interval 6 month);dayofweek(date) 返回date所代表的⼀星期中的第⼏天(1~7)dayofmonth(date) 返回date是⼀个⽉的第⼏天(1~31)dayofyear(date) 返回date是⼀年的第⼏天(1~366)dayname(date) 返回date的星期名,如:select dayname(current_date);from_unixtime(ts,fmt) 根据指定的fmt格式,格式化unix时间戳tshour(time) 返回time的⼩时值(0~23)minute(time) 返回time的分钟值(0~59)month(date) 返回date的⽉份值(1~12)monthname(date) 返回date的⽉份名,如:select monthname(current_date);now() 返回当前的⽇期和时间quarter(date) 返回date在⼀年中的季度(1~4),如select quarter(current_date);week(date) 返回⽇期date为⼀年中第⼏周(0~53)year(date) 返回⽇期date的年份(1000~9999)⼀些⽰例:获取当前系统时间:select from_unixtime(unix_timestamp());select extract(year_month from current_date);select extract(day_second from current_date);select extract(hour_minute from current_date);返回两个⽇期值之间的差值(⽉数):select period_diff(200302,199802);在mysql中计算年龄:select date_format(from_days(to_days(now())-to_days(birthday)),'%y')+0 as age from employee;这样,如果brithday是未来的年⽉⽇的话,计算结果为0。
数据库常用函数表
DTOC(DATE())
11/01/2002
DTOS(D)
把日期转成年月日式的字符串
DTOS(DATE())
CTOT(C)
字符串转成日期时间型
CTOT(11/01/2002 10:30:50am)
11/01/2002 10:30:50am
DTOT(D)
日期型转为日期时间型
DTOT(DATE())
ROUND(3.14159,4)
3.1416
RAND()
随机小数(0<RAND()<1)
0.0001,0.333,0.9999
Sum(x)
对一列求和计算
Sum(字段名)
Avg(x)
对一列求平均计算
Avg(字段名)
平均数
MAX(x)
求一列中的最大值
MAX(字段名)
最大值
MIN(x,y)
求一TE())
12
DOW(D)
求星期几(数值)
DOW(DATE())
1
CDOW(D)
求星期几(英文)
CDOW(DATE())
sunday
TIME(D)
求当前时间
TIME(DATE())
10:20:38am
4、数据类型转换函数
函数名
操作
例
结果
ASC(S)
求第一个字符串的ASCII码
ASC("what")
11/25/2001 00:00:01am
TTOC(T)
日期时间型转为字符型
TTOC(DATETIME())
11/25/2001 00:00:01am
TTOD(T)
日期时间型转为日期型
postgre常用函数
postgre常用函数PostgreSQL是一种开源对象关系数据库管理系统,它具有许多优良的功能和特性,其中包括一组强大的内置函数。
在本文中,我们将介绍PostgreSQL中的一些常用函数,以帮助您更好地了解PostgreSQL。
数学函数1. abs(x) -返回参数x的绝对值。
2. cbrt(x) -返回x的立方根。
3. ceil(x) -返回大于或等于x的最小整数。
4. floor(x) -返回小于或等于x的最大整数。
5. mod(x, y) -返回x除以y的余数。
6. pi() - 返回π的值。
7. round(x, d) -将x四舍五入到d位小数。
字符串函数日期和时间函数1. age(date1, date2) -返回date1与date2之间的年龄。
2. extract(field from timestamp) -从时间戳中提取指定的日期或时间部分,如年、月、日、时、分、秒等。
3. now() -返回当前日期和时间。
4. date_part(field, timestamp) -与Extract类似,也是从时间戳中提取指定的日期或时间部分。
5. timestampadd(interval, n, timestamp) -在时间戳中添加指定的时间间隔。
6. timestampdiff(interval, timestamp1, timestamp2) -计算时间戳之间的时间间隔。
聚合函数1. avg(expression) -计算指定表达式的平均值。
2. count(expression) -返回指定表达式的行数。
3. max(expression) -返回指定表达式的最大值。
4. min(expression) -返回指定表达式的最小值。
5. sum(expression) -计算指定表达式的总和。
其他常用函数总结PostgreSQL是一种十分强大的数据库管理系统,这些内置函数大为增强了其实用价值和功能。
MySQL数据库常用函数大全
MySQL数据库常用函数大全字符串函数字符串函数是最常用的一种函数,MySQL支持很多种字符串函数。
下列是MySQL支持的字符串函数表。
1、LOWER(str) 和UPPER(str)函数:用于转换大小写。
2、CONCAT(s1,s2…sn): 把传入的参数拼接成一个字符串。
任何和NULL进行字符串拼接的结果都是NULL。
3、LEFT(str,x) 和RIGHT(str,x) 函数:分别返回字符串最左边的x个字符和最右边的x个字符。
如果第二个参数是NULL,那么将不会返回任何字符串。
4、INSERT(str,x,y,instr): 将字符串str 从指定x的位置开始,取y个长度的字串替换为instr。
5、LTRIM(str)和RTRIM(str)分别表示去掉字符串str左侧和右侧的空格。
6、REPEAT(str,x)函数:返回str 重复x次的结果。
7、TRIM(str)函数,用于去掉目标字符串的空格。
8、SUBSTRING(str,x,y)函数,返回从字符串str中第x位置起y个字符长度的字符串。
9、LPAD(str,n,pad)和RPAD(str,n,pad)函数,用字符串pad对str左边和右边进行填充,直到长度为n个字符长度。
10、STRCMP(s1,s2)用于比较字符串s1和s2的ASCII值大小。
如果s1<s2,则返回-1,如果s1=s2,则返回0,如果s1>s2,则返回1。
11、REPLACE(str,a,b),用字符串b替换字符串str中所有出现的字符串a。
数值函数MySQL支持数值函数,这些函数能够处理很多数值运算。
1、A B S ( x )函数,返回x 的绝对值2、C E I L ( x )函数,返回大于x 的整数。
、M O D ( x , y ),对x 和y 进行取模操作。
、R O U N D ( x , y )返回x 四舍五入后保留位小数的值,如果是整数,那么y 为就是0,如不指定,那么y 默认也是0。
数据库常用函数
数据库常用函数1.绝对值S:select abs(-1) valueO:select abs(-1) value from dual2.取整(大)S:select ceiling(-1.001) valueO:select ceil(-1.001) value from dual3.取整(小)S:select floor(-1.001) valueO:select floor(-1.001) value from dual4.取整(截取)S:select cast(-1.002 as int) valueO:select trunc(-1.002) value from dual5.四舍五入S:select round(1.23456,4) value 1.23460O:select round(1.23456,4) value from dual 1.23466.e为底的幂S:select Exp(1) value 2.7182818284590451O:select Exp(1) value from dual 2.718281827.取e为底的对数S:select log(2.7182818284590451) value 1O:select ln(2.7182818284590451) value from dual; 18.取10为底对数S:select log10(10) value 1O:select log(10,10) value from dual; 19.取平方S:select SQUARE(4) value 16O:select power(4,2) value from dual 1610.取平方根S:select SQRT(4) value 2O:select SQRT(4) value from dual 211.求任意数为底的幂S:select power(3,4) value 81O:select power(3,4) value from dual 8112.取随机数S:select rand() valueO:select sys.dbms_random.value(0,1) value from dual;13.取符号S:select sign(-8) value -1O:select sign(-8) value from dual -1----------数学函数14.圆周率S:SELECT PI() value 3.1415926535897931O:不知道15.sin,cos,tan 参数都以弧度为单位例如:select sin(PI()/2) value 得到1(SQLServer)16.Asin,Acos,Atan,Atan2 返回弧度17.弧度角度互换(SQLServer,Oracle不知道) DEGREES:弧度-〉角度RADIANS:角度-〉弧度---------数值间比较18. 求集合最大值S:select max(value) value from(select 1 valueunionselect -2 valueunionselect 4 valueunionselect 3 value)aO:select greatest(1,-2,4,3) value from dual19. 求集合最小值S:select min(value) value from(select 1 valueunionselect -2 valueunionselect 4 valueunionselect 3 value)aO:select least(1,-2,4,3) value from dual20.如何处理null值(F2中的null以10代替)S:select F1,IsNull(F2,10) value from TblO:select F1,nvl(F2,10) value from Tbl--------数值间比较21.求字符序号S:select ascii('a') valueO:select ascii('a') value from dual22.从序号求字符S:select char(97) valueO:select chr(97) value from dual23.连接S:select '11'+'22'+'33' valueO:select CONCAT('11','22')||33 value from dual23.子串位置--返回3S:select CHARINDEX('s','sdsq',2) valueO:selectINSTR('sdsq','s',2) value from dual23.模糊子串的位置--返回2,参数去掉中间%则返回7S:select patindex('%d%q%','sdsfasdqe') valueO:oracle没发现,但是instr可以通过第四霾问 刂瞥鱿执问?BR> select INSTR('sdsfasdqe','sd',1,2) value from dual 返回624.求子串S:select substring('abcd',2,2) valueO:select substr('abcd',2,2) value from dual25.子串代替返回aijklmnefS:SELECT STUFF('abcdef', 2, 3, 'ijklmn') valueO:SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual26.子串全部替换S:没发现O:select Translate('fasdbfasegas','fa','我' ) value from dual27.长度S:len,datalengthO:length28.大小写转换lower,upper29.单词首字母大写S:没发现O:select INITCAP('abcd dsaf df') value from dual30.左补空格(LPAD的第一个参数为空格则同space函数)S:select space(10)+'abcd' valueO:select LPAD('abcd',14) value from dual31.右补空格(RPAD的第一个参数为空格则同space函数)S:select 'abcd'+space(10) valueO:select RPAD('abcd',14) value from dual32.删除空格S:ltrim,rtrimO:ltrim,rtrim,trim33. 重复字符串S:select REPLICATE('abcd',2) valueO:没发现34.发音相似性比较(这两个单词返回值一样,发音相同)S:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe')O:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') from dualSQLServer中用SELECT DIFFERENCE('Smithers', 'Smythers') 比较soundex的差返回0-4,4为同音,1最高--------------日期函数35.系统时间S:select getdate() valueO:select sysdate value from dual36.前后几日直接与整数相加减37.求日期S:select convert(char(10),getdate(),20) valueO:select trunc(sysdate) value from dualselect to_char(sysdate,'yyyy-mm-dd') value from dual38.求时间S:select convert(char(8),getdate(),108) valueO:select to_char(sysdate,'hh24:mm:ss') value from dual39.取日期时间的其他部分S:DATEPART 和DATENAME 函数(第一个参数决定)O:to_char函数第二个参数决定参数---------------------------------下表需要补充year yy, yyyyquarter qq, q (季度)month mm, m (m O无效)dayofyear dy, y (O表星期)day dd, d (d O无效)week wk, ww (wk O无效)weekday dw (O不清楚)Hour hh,hh12,hh24 (hh12,hh24 S无效)minute mi, n (n O无效)second ss, s (s O无效)millisecond ms (O无效)----------------------------------------------40.当月最后一天S:不知道O:select LAST_DAY(sysdate) value from dual41.本星期的某一天(比如星期日)S:不知道O:SELECT Next_day(sysdate,7) vaule FROM DUAL;42.字符串转时间S:可以直接转或者select cast('2004-09-08'as datetime) value O:SELECT To_date('2004-01-05 22:09:38','yyyy-mm-dd hh24-mi-ss') vaule FROM DUAL;43.求两日期某一部分的差(比如秒)S:select datediff(ss,getdate(),getdate()+12.3) valueO:直接用两个日期相减(比如d1-d2=12.3)SELECT (d1-d2)*24*60*60 vaule FROM DUAL;44.根据差值求新的日期(比如分钟)S:select dateadd(mi,8,getdate()) valueO:SELECT sysdate+8/60/24 vaule FROM DUAL;45.求不同时区时间S:不知道O:SELECT New_time(sysdate,'ydt','gmt' ) vaule FROM DUAL;-----时区参数,北京在东8区应该是Ydt-------AST ADT 大西洋标准时间BST BDT 白令海标准时间CST CDT 中部标准时间EST EDT 东部标准时间GMT 格林尼治标准时间HST HDT 阿拉斯加—夏威夷标准时间MST MDT 山区标准时间NST 纽芬兰标准时间PST PDT 太平洋标准时间YST YDT YUKON标准时间。
visual foxpro 数据库 函数大全
【格式】COL ( )
ROW()
【功能】COL ( )返回光标的列坐标值,ROW ( )返回光标的行坐标值。
11.打印机列坐标和行坐标函数PCOL( ),PROW( )
【格式】PCOL( )
PROW()
【功能】返回打印机打印头所处位置的列坐标和行坐标。
【格式】INT(<nExp>)
【功能】计算nExp的值,返回该值的整数部分。
4.上界函数CEILING( )
【格式】CEILING(<nExp>)
【功能】计算nExp的值,返回一个大于或等于该值的最小整数。
5.下界函数FLOOR( )
【格式】FLOOR(<nExp>)
【功能】计算nExp的值,返回一个小于或等于该值的最大整数。
6.当前记录号函数RECNO()
【格式】RECNO([<工作区号> | <别名>])
【功能】返回指定工作区中表的当前记录的记录号。对于空表返回值为1。
7.当前记录逻辑删除标志测试函数DELETED( )
【格式】DELETED([<工作区号> | <别名>])
【功能】测试指定工作区中表的当前记录是否被逻辑删除。如果当前记有逻辑删除标记,函数返回真(.T.),否则为假(.F.)。
4.取子串函数SUBSTR( )
【格式】SUBSTR (<cExp>,<nExp1> [,< nExp2>] )
【功能】返回从串cExp中第nExp1个字符开始,截取nExp2个字符的子串。
DB2数据库常用的函数
DB2数据库常⽤的函数1.value函数语法value(表达式1,表达式2)value函数是⽤返回⼀个⾮空的值,当其第⼀个参数⾮空,直接返回该参数的值,如果第⼀个参数为空,则返回第⼀个参数的值。
eg:表⽰如果T1.ID为空,则返回空串,如果不为空,则返回T1.IDselect value(ID,'') from T12.coalesce函数语法coalesce(arg1,arg2)coalesce返回参数集中第⼀个⾮null参数3.length函数语法length函数返回参数的长度eg:select length(name) from T14.lcase,lower函数语法lcase(),lower()函数返回定长,变长字符串的⼩写形式eg:select lcase(name),lower(name) from T15.ucase,upper函数语法:ucase(),upper()函数返回定长,变长字符串的⼤写形式eg:select ucase(name),upper(name) from T16.ltrim,rtrim语法:ltrim(),rtrim()ltrim,rtrim函数从char varchar graphic或者vargraphic中去掉左侧或右侧的空格eg:select ltrim(name),rtrim(name) from T17.left,right函数语法:left(arg,length),right(arg,length)left,right函数返回arg最左边,最右边的length个字符串,arg可以是char或binarystringeg:select left(name,2),right(name,2) from T18.concat 函数语法:concat(arg1,,arg2)concat函数返回两个字符串的连接eg:select concat(first_name,last_name) from T19.locate函数语法:locate(arg1,arg2,<pos>)locate函数在arg2中查找arg1第⼀次出现的位置,如果指定pos,则从arg2的pos处开始查找arg1的位置eg:select locate('a',name) from T110.posstr函数语法:posstr(表达式1,表达式2)posstr函数返回表达式2在表达式1中的位置11.repeat函数语法:repeat(arg1,num_times)repeat函数返回arg1被重复num_times次的字符串eg:select repeat(name,2) from T112.replace函数语法:replace(表达式1,表达式2,表达式3)replace函数⽤表达式3代替表达式1中的所有表达式2eg:select replace('romannd','nnd','ccb') from T113.space函数语法:space(size)函数返回⼀个包含size空格的字符串。
excel 数据库函数
excel 数据库函数Excel 数据库函数Excel 数据库函数是一种非常强大的工具,它可以帮助用户在Excel 中快速地处理大量的数据。
下面我们来介绍一些常用的Excel 数据库函数。
1. SUMIF 函数SUMIF 函数可以根据指定的条件对数据进行求和。
例如,我们可以使用SUMIF 函数来计算某个部门的总销售额。
其语法为:SUMIF(range, criteria, [sum_range])。
2. COUNTIF 函数COUNTIF 函数可以根据指定的条件对数据进行计数。
例如,我们可以使用COUNTIF 函数来计算某个部门的员工人数。
其语法为:COUNTIF(range, criteria)。
3. AVERAGEIF 函数AVERAGEIF 函数可以根据指定的条件对数据进行平均值计算。
例如,我们可以使用AVERAGEIF 函数来计算某个部门的平均销售额。
其语法为:AVERAGEIF(range, criteria, [average_range])。
4. MAX 函数MAX 函数可以返回指定数据范围中的最大值。
例如,我们可以使用MAX 函数来找出某个部门的最高销售额。
其语法为:MAX(number1, [number2], …)。
5. MIN 函数MIN 函数可以返回指定数据范围中的最小值。
例如,我们可以使用MIN 函数来找出某个部门的最低销售额。
其语法为:MIN(number1, [number2], …)。
6. VLOOKUP 函数VLOOKUP 函数可以根据指定的值在数据表中查找对应的值。
例如,我们可以使用VLOOKUP 函数来查找某个员工的工资。
其语法为:VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup])。
7. HLOOKUP 函数HLOOKUP 函数与 VLOOKUP 函数类似,不同之处在于它是在水平方向上查找数据。
数据库统计函数
数据库统计函数
数据库统计函数是一类用来从记录集中抽取数据统计信息的函数,它可以直接以查询
语句的形式检索到数据库中的指定信息。
这类函数一般分为聚合函数和分组框函数。
聚合函数是一种能够根据提供的参数计算出指定列的总和、平均值或极值的函数。
常
见的聚合函数有 Sum(求和)、Avg(求平均值)、Max(求最大值)、Min(求最小值)等。
这种函数可以对某个列进行数学计算,把整个查询出来的表数据中的每个记录按照指
定的值进行处理,形成一个数值汇总的表达式。
分组框函数是一种能够根据记录中的某个或多个属性字段实现数据记录集分组的函数,它可以根据分组后的信息统计总和、平均值、极值等信息,以及按照某个字段进行排序,
并显示前几行和分组时结果数量。
其中常用的函数包括:group by(分组)、 having
(前置条件)、 Order by(排序)等。
有些数据库能够实现多层级分组,如果使用聚合函数,就需要多次计算,而分组框函
数可以使用一次sql语句就实现对多个属性字段的分组查询。
数据库统计函数不仅可以快速检索指定数据,还可以把数据转变成一种更容易掌握和
分析的形式,在数据分析和统计分析中有很大的作用。
数据库5种聚合函数的具体含义
数据库5种聚合函数的具体含义数据库中的聚合函数是SQL语言中非常重要的一部分,它允许我们在数据集上进行计算和汇总操作。
常见的数据库聚合函数有5种,它们分别是:COUNT、SUM、AVG、MIN和MAX。
每个聚合函数都有其特定的用途和功能,下面我将详细介绍这5种聚合函数的具体含义。
1. COUNT(计数)COUNT函数用于计算指定列或表中的行数。
它可以用来统计某个表中的记录数量或某个列中的非空值数量。
在使用COUNT函数时,可以使用WHERE子句来指定条件,从而筛选需要计数的行。
COUNT函数还可以与DISTINCT关键字一起使用,以得到唯一值的计数结果。
2. SUM(求和)SUM函数用于计算指定列的数值之和。
它主要适用于数值型数据,可以用来统计某个表中某一列的总和,比如销售额的总和或某个时间段内的销售总量。
使用SUM函数时,要确保被计算的列是可以进行数值计算的。
3. AVG(平均值)AVG函数用于计算指定列的平均值。
它和SUM函数类似,但不同之处在于它返回的是列的平均值而不是总和。
AVG函数主要适用于数值型数据,可以用来计算某个表中某一列的平均值,比如平均销售额或平均消费金额。
4. MIN(最小值)MIN函数用于找出指定列的最小值。
它可以用来查找某个表中某一列的最小值,比如最低销售额或最低温度。
MIN函数也可以与其他聚合函数一起使用,比如找到某列的最小值,并计算它的平均值。
5. MAX(最大值)MAX函数用于找出指定列的最大值。
它可以用来查找某个表中某一列的最大值,比如最高销售额或最高温度。
和MIN函数类似,MAX函数也可以与其他聚合函数一起使用,比如找到某列的最大值,并计算它的总和。
以上就是数据库中常见的5种聚合函数的具体含义。
它们在数据处理和分析中发挥着重要的作用,可以帮助我们对数据进行汇总、计算和统计。
通过对这些聚合函数的理解和运用,我们可以更好地处理和分析数据,为决策和业务提供有价值的支持。
数据库常用函数
数据库常⽤函数函数对于函数需要⼤家了解的有:1、函数名2、除了&宏函数外,所有函数必须加()3、函数的作⽤4、函数的参数5、函数的返回值及其类型数值运算函数: INT()、ABS()、MAX()、MIN()、SQRT()、ROUND()、MOD()字符处理函数: LEN()、A T()、SPACE()、SUBSTR()、LEFT()、RIGHT()TRIM=RTRIM(TRIM\ALLTRIM\LTRIM\RTRIM)、STUFF()、&:宏函数转换函数:LOWER()、UPPER()、CTOD()、DTOC()、STR()、V AL() ASC()、CHR()⽇期时间函数: DA TE()、TIME()、YEAR()、MONTH()、DAY()测试函数: RECNO()、BOF()、EOF()、FOUND()、FILE()、DBF()、RECCOUNT()、SELECT()、TYPE()、IIF()、其它:ROW()、COL()、INKEY()、READKEY()1.数值处理函数(1)求对数函数LOG()【格式】LOG(<数值表达式>)【功能】返回<数值表达式>的⾃然对数值。
【说明】<数值表达式>值必须⼤于零。
【例如】输⼊语句:?LOG(16.5),LOG(10),LOG(1)显⽰结果: 2.80 2.30 0.00(2)求四舍五⼊函数ROUND()【格式】ROUND(<数值表达式1>,<数值表达式2>)【功能】返回<数值表达式1>按<数值表达式2>所指定的保留⼩数位数进⾏四舍五⼊的值。
若<数值表达式2>的值为负,则返回⼩数点左边为<数值表达式2>绝对值个数零的整数值。
【例如】:输⼊语句:?ROUND(68.345,2),ROUND(68.745,0),ROUND(68.345,-1),ROUND(68.345,-2)显⽰结果:68.35 69 70100注意:在执⾏函数ROUND(68.345,-1)时,⼩数点左边的数是两位68,由于参数2为-1,则返回值是整数且应带⼀个0,故经四舍五⼊后,8进位到6则⾸位变为7,第⼆位按规定是0。
数据库中的常用函数
重点内容:
• • • •
数字类型处理
字符串类型处理
时间类型处理
类型转换
一、数字
1、算术运算和数学函数
所有类型的数字字段存储的数据都具有相同的基本类型,就是数字。算 术运算是我们对数字类型数据的常见处理方式,而最基本的算术运算是我们 使用基本的算术运算符,比如“+”、“-”、“*”、“/”等进行的数学运算。 大部分的算术运算我们大家都已经很熟悉了,对一些较复杂的具体的问题还 有现成的数学公式可以查阅使用,有了这些,我们就能够针对某个要处理的 问题,列出所需的算术表达式来。 在数据库系统中,许多基本的算术运算已经被作为数学函数整理出来, 用户不再需要自己建立复杂而具体的算术式,只需要调用这些数学函数,将 需要进行计算的数据作为函数的参数输入,就可以直接得到答案。数学函数 也可以使用在算术表达式中,大大简化了我们的算术运算。
三、时间
2、日期时间函数
SQL语句中存在日期时间数据类型的数值,就有相应的日期时间函数来对 其进行数据处理。这些日期时间函数在不同的数据库可能有着不同的函数名 称,所以在使用这些函数前一定要先查阅当前使用的数据库系统的文档资料。
三、时间
3、日期时间的算法
日期时间数据的运算类型不多,包括日期时间的比较、加减日期时间、 格式化时间值等。但是日期时间的运算在某种程度上是比数字和字符串更复 杂一些的,因为,在不同的数据库系统中,对日期时间的处理方法并不一样。 例如,Oracle只能提供DATE一种时间日期类型,而Transact-SQL则可以提供 大量的类型。另外,在不同的数据库系统中,对时间日期进行格式化和其它 处理的函数也会有很大的差别,通常会完全不同。
数据类型 格式 范围 ———— —————————— —————————— DATE YYYY-MM-DD 0001-01-01 TO 9999-12-31 TIME HH:MI:SS.nn 00:00:00 TO 23:59:61.999 TIMESTAMP YYYY-MM-DD HH:MI:SS.nn 0001-01-01 00:00:00 TO 9999-12-31 23:59:61.999
Access数据库常用标准函数新
Access数据库常用标准函数一、算术函数1.绝对值函数:Abs(<表达式>)返回数值表达式的绝对值。
如Abs(-3)=32.向下取整函数:Int(<数值表达式>)返回数值表达式的向下取整数的结果,参数为负值时返回小于等于参数值的第一负数。
3.取整函数:Fix(<数值表达式>)返回数位表达式的整数部分,参数为负值时返回大于等于参数值的第一负数。
例如:Int(3.25)=3,Fix(3.25)=3但Int(-3.25)= -4,Fix(-3.25)= -34.四舍五入函数:Round(<数值表达式>[,<表达式>])按照指定的小数位数进入四舍五入运算的结果。
[<表达式>]是进入四舍五入运算小数点右边应保留的位数。
例如:Round(3.255,1)= 3.3;Round(3. 754,2)= 3.75;Round(3.754,0)= 45.开平方函数:Sqr(<数值表达式>)计算数值表达式的平方根。
例如:Sqr(9)= 36.产生随机数函数:Rnd(<数值表达式>)产生一个0-1之间的随机数,为单精度类型。
例如:Int(100 * Rnd)’产生[0,99]的随机整数Int(101 * Rnd)’产生[0,100]的随机整数7..求平均值函数Avg()例如:在tstud表中求小于所有学生年龄的平均值的学生<(select avg([年龄]) from tstud)8.. 求和函数sum()二、字符串函数1.字符串检索函数:InStr([Start,] <Strl>,<Stf2> [,Compare])检索子字符申Str2在字符串Strl中最早出现的位置,返回一整型数。
Start为可选参数,为数值式,设置检索的起始位置。
如省略,从第一个字符开始检索;注意,如果Strl的申长度为零,或Str2表示的申检索不到,则InStr返回0;如果Str2的串长度为零,InStr返回Start的值。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据库常用函数一、基础1、说明:创建数据库CREATE DATABASE database-name2、说明:删除数据库drop database dbname3、说明:备份和还原备份:exp dsscount/sa@dsscount owner=dsscountfile=C:\dsscount_data_backup\dsscount.dmplog=C:\dsscount_data_backup\outputa.log还原:imp dsscount/sa@dsscountfile=C:\dsscount_data_backup\dsscount.dmp full=y ignore=ylog=C:\dsscount_data_backup\dsscount.log statistics=none4、说明:创建新表create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)CREATE TABLE ceshi(id INT not null identity(1,1) PRIMARY KEY,NAME VARCHAR(50),age INT) id为主键,不为空,自增长根据已有的表创建新表:A:create table tab_new like tab_old (使用旧表创建新表)B:create table tab_new as select col1,col2… from tab_old definition only5、说明:删除新表drop table tabname6、说明:增加一个列Alter table tabname add column col type注:列增加后将不能删除。
DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:添加主键: Alter table tabname add primary key(col)说明:删除主键: Alter table tabname drop primary key(col)8、说明:创建索引:create [unique] index idxname on tabname(col….) 删除索引:drop index idxname注:索引是不可更改的,想更改必须删除重新建。
9、说明:创建视图:create view viewname as select statement删除视图:drop view viewname10、说明:几个简单的基本的sql语句选择:select * from table1 where 范围插入:insert into table1(field1,field2) values(value1,value2)删除:delete from table1 where 范围更新:update table1 set field1=value1 where 范围查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!排序:select * from table1 order by field1,field2 [desc]总数:select count as totalcount from table1求和:select sum(field1) as sumvalue from table1平均:select avg(field1) as avgvalue from table1最大:select max(field1) as maxvalue from table1最小:select min(field1) as minvalue from table111、说明:几个高级查询运算词A: UNION 运算符UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。
当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。
两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。
当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。
当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、说明:使用外连接A、left (outer) join:左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.cB:right (outer) join:右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full/cross (outer) join:全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
12、分组:Group by:一张表,一旦分组完成后,查询后只能得到组相关的信息。
组相关的信息:(统计信息) count,sum,max,min,avg 分组的标准)在SQLServer中分组时:不能以text,ntext,image类型的字段作为分组依据在selecte统计函数中的字段,不能和普通的字段放在一起;13、对数据库进行操作:分离数据库: sp_detach_db; 附加数据库:sp_attach_db 后接表明,附加需要完整的路径名14.如何修改数据库的名称:sp_renamedb 'old_name', 'new_name'二、提升1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)法一:select * into b from a where 1<>1(仅用于SQlServer)法二:select top 0 * into b from a2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)insert into b(a, b, c) select d,e,f from b;3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where..4、说明:子查询(表名1:a 表名2:b)select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)5、说明:显示文章、提交人和最后回复时间select a.title,ername,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b6、说明:外连接查询(表名1:a 表名2:b)select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c7、说明:在线视图查询(表名1:a )select * from (SELECT a,b,c FROM a) T where t.a > 1;8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括select * from table1 where time between time1 and time2select a,b,c, from table1 where a not between 数值1 and 数值29、说明:in 的使用方法select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)10、说明:两张关联表,删除主表中已经在副表中没有的信息delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )11、说明:四表联查问题:select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....12、说明:日程安排提前五分钟提醒SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>513、说明:一条sql 语句搞定数据库分页select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段具体实现:关于数据库分页:declare @start int,@end int@sql nvarchar(600)set @sql=’select top’+str(@end-@start+1)+’+from T where rid not in(select top’+str(@str-1)+’Rid from T where Rid>-1)’exec sp_executesql @sql注意:在top后不能直接跟一个变量,所以在实际应用中只有这样的进行特殊的处理。
Rid为一个标识列,如果top后还有具体的字段,这样做是非常有好处的。