函数SQL语句大全(很全)sql语句用法

sql语句大全  时间:2021-02-27  阅读:()

SQL语句大全

--语句功能

--数据操作

SELECT--从数据库表中检索数据行和列I N S E RT--向数据库表添加新数据行DELETE--从数据库表中删除数据行UPDATE--更新数据库表中的数据--数据定义

CREATE TABLE--创建一个数据库表DROPTABLE--从数据库中删除表ALTERTABLE--修改数据库表结构CREATE VIEW--创建一个视图DROPVIEW--从数据库中删除视图CREATE INDEX--为数据库表创建一个索引DROP INDEX--从数据库中删除索引CREATE PROCEDURE--创建一个存储过程DROP PROCEDURE--从数据库中删除存储过程CREATETRIGGER--创建一个触发器DROPTRIGGER--从数据库中删除触发器CREATE SCHEMA--向数据库添加一个新模式DROPSCHEMA--从数据库中删除一个模式CREATE DOMAIN--创建一个数据值域ALTER DOMAIN--改变域定义

DROP DOMAIN--从数据库中删除一个域--数据控制

GRANT--授予用户访问权限

DENY--拒绝用户访问

REVOKE--解除用户访问权限

--事务控制

COMMIT--结束当前事务

ROLLBACK--中止当前事务

SET TRANSACTION--定义当前事务数据访问特征--程序化SQL

DECLARE--为查询设定游标

EXPLAN--为查询描述数据访问计划OPEN--检索查询结果打开一个游标FETCH--检索一行查询结果

CLOSE--关闭游标

PREPARE--为动态执行准备SQL语句EXECUTE--动态地执行SQL语句DESCRIBE--描述准备好的查询

---局部变量declare@id char(10)

--set@id=''select@id=''

---全局变量

---必须以@@开头

--IFELSEdeclare@x int@y int@z intselect@x=1@y=2@z=3if@x>@yprint 'x>y' --打印字符串'x>y'else if@y>@zprint 'y>z'else print 'z>y'

--CASEuse panguupdate employeeset e_wage=casewhenjob_level=’1’ then e_wage*1 08whenjob_level=’2’ then e_wage*1 07whenjob_level=’3’ then e_wage*1 06else e_wage*1 05end

--WHILE CONTINUE BREAKdeclare@x int@y int@c intselect@x=1@y=1whi le@x<3beginprint@x--打印变量x的值whi le@y<3beginselect@c=100*@x+@yprint@c--打印变量c的值

select@y=@y+1endselect@x=@x+1select@y=1end

--WAITFOR

--例等待1小时2分零3秒后才执行SELECT语句waitfor delay’01 :02:03’select*from employee

--例等到晚上11点零8分后才执行SELECT语句waitfor time’23:08:00’select*from employee

***SELECT***select*(列名) from table_name(表名)where column_name operatorvalueex:(宿主)select*from stock_information where stockid=str(nid)stockname='str_name'

stockname l ike'%find this%'stockname l ike'[a-zA-Z]%' --------- ([]指定值的范围)stockname l ike'[^F-M]%' --------- (^排除指定范围)

---------只能在使用l ike关键字的where子句中使用通配符)or stockpath='stock_path'or stocknumber<1000and stockindex=24not stock***='man'stocknumber between 20 and 100stocknumber in(10,20,30)order by stockid desc(asc) ---------排序 desc-降序 asc-升序order by 1 ,2---------by列号stockname=(select stockname from stock_information where stockid=4)

---------子查询

---------除非能确保内层select只返回一个行的值

---------否则应在外层where子句中用一个in限定符select distinct column_name form table_name---------distinct指定检索独有的列值不重复

select stocknumber ,"stocknumber+10"=stocknumber+10 from table_nameselect stockname, "stocknumber"=count(*) from table_name group by stockname---------group by将表按行分组,指定列中有相同的值having count(*)=2---------having选定指定的组select*from table 1 , table2where table1 id*=table2 id--------左外部连接 table1中有的而table2中没有得以nul l表示table1 id=* table2 id--------右外部连接select stockname from table1union[al l] -----union合并查询结果集 al l-保留重复行select stockname from table2

***insert***insert into table_name(Stock_name,Stock_number)value("xxx","xxxx")value(select Stockname,Stocknumber from Stock_table2)---value为select语句

******update table_name set Stockname="xxx" [where Stockid=3]

Stockname=default

Stockname=nul l

Stocknumber=Stockname+4

***delete***

delete from table_name where Stockid=3truncate table_name-----------删除表中所有行仍保持表的完整性drop table table_name---------------完全删除表

***alter table*** ---修改数据库表结构alter table database ownertable_name add column_name char(2)nul lsp_helptable_name----显示表已有特征create table table_name(name char(20),age smal l int, lname varchar(30))insert into table_name select -----实现删除列的方法创建新表alter table table_name drop constraint Stockname_default ----删除Stockname的default约束

***fu nction(/*常用函数*/)***

----统计函数----

AVG--求平均值

COUNT--统计数目

MAX--求最大值

MIN--求最小值

SUM--求和

--AVGuse panguselect avg(e_wage)as dept_avgWagefrom employeegroup bydept_id

--M AX

--求工资最高的员工姓名use panguselect e_name

from employee

where e_wage=

(select max(e_wage)from employee)

--STDEV()

--STDEV()函数返回表达式中所有数据的标准差

--STDEVP()

--STDEVP()函数返回总体标准差

--VAR()

--VAR()函数返回表达式中所有值的统计变异数

--VARP()

--VARP()函数返回总体变异数

----算术函数----

/***三角函数***/

SIN(float_expression) --返回以弧度表示的角的正弦COS(float_expression) --返回以弧度表示的角的余弦TAN(float_expression) --返回以弧度表示的角的正切COT(float_expression) --返回以弧度表示的角的余切

/***反三角函数***/

ASIN(float_expression) --返回正弦是FLOAT值的以弧度表示的角ACOS(float_expression) --返回余弦是FLOAT值的以弧度表示的角ATAN(float_expression) --返回正切是FLOAT值的以弧度表示的角ATAN2(float_expression1 ,float_expression2)

--返回正切是float_expression1 /float_expres-sion2的以弧度表示的角DEGREES(numeric_expression)

--把弧度转换为角度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT类型

RADIANS(numeric_expression) --把角度转换为弧度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT类型

EXP(float_expression) --返回表达式的指数值

LOG(float_expression) --返回表达式的自然对数值

LOG10(float_expression)--返回表达式的以10为底的对数值

SQRT(float_expression) --返回表达式的平方根

/***取近似值函数***/

CEILING(numeric_expression) --返回>=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT类型

FLOOR(numeric_expression) --返回<=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT类型

ROUND(numeric_expression) --返回以integer_expression为精度的四舍五入值返回的数据--类型与表达式相同可为INTEGER/MONEY/REAL/FLOAT类型

ABS(numeric_expression) --返回表达式的绝对值返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT类型

SIGN(numeric_expression) --测试参数的正负号返回0零值1正数或-1负数返回的数据类型--与表达式相同可为INTEGER/MONEY/REAL/FLOAT类型

PI() --返回值为π即397936

RAND([integer_expression]) --用任选的[integer_expression]做种子值得出0-1间的随机浮点数

----字符串函数----

ASCI I() --函数返回字符表达式最左端字符的ASCI I码值

CHAR() --函数用于将ASCI I码转换为字符

--如果没有输入0~255之间的ASCI I码值CHAR函数会返回一个NULL值LOWER() --函数把字符串全部转换为小写

UPPER() --函数把字符串全部转换为大写

STR() --函数把数值型数据转换为字符型数据

LTRIM() --函数把字符串头部的空格去掉

RT R I M() --函数把字符串尾部的空格去掉

LEFT(),RIGHT(),SUBSTRING() --函数返回部分字符串

CHARINDEX(),PATINDEX() --函数返回字符串中某个指定的子串出现的开始位置SOUNDEX() --函数返回一个四位字符码

--SOUNDEX函数可用来查找声音相似的字符串但SOUNDEX函数对数字和汉字均只返回0值DIFFERENCE() --函数返回由SOUNDEX函数返回的两个字符表达式的值的差异--0两个SOUNDEX函数返回值的第一个字符不同

--1两个SOUNDEX函数返回值的第一个字符相同

--2两个SOUNDEX函数返回值的第一二个字符相同

--3两个SOUNDEX函数返回值的第一二三个字符相同

--4两个SOUNDEX函数返回值完全相同

QUOTENAME() --函数返回被特定字符括起来的字符串/*select quotename('abc' , '{')quotename('abc')

运行结果如下

----------------------------------{

{abc} [abc]*/

REPLICATE() --函数返回一个重复character_expression指定次数的字符串/*select repl icate('abc' ,3) repl icate( 'abc' , -2)

运行结果如下

----------- -----------abcabcabc NULL*/

REVERSE() --函数将指定的字符串的字符排列顺序颠倒REPLACE() --函数返回被替换了指定子串的字符串

/*select replace('abc123g' , '123' , 'def')

运行结果如下

----------- -----------abcdefg*/

SPACE() --函数返回一个有指定长度的空白字符串

STUFF() --函数用另一子串替换字符串指定位置长度的子串

----数据类型转换函数----

CAST()函数语法如下

CAST() (<expression>AS<data_type>[ length])

CONVERT()函数语法如下

CONVERT() (<data_type>[ length],<expression>[,style])select cast(100+99 as char)convert(varchar(12),getdate())

运行结果如下

------------------------------ ------------

199Jan 152000

----日期函数----

DAY() --函数返回date_expression中的日期值

MONTH() --函数返回date_expression中的月份值

YEAR() --函数返回date_expression中的年份值

DATEADD(<datepart>,<number>,<date>)

--函数返回指定日期date加上指定的额外日期间隔number产生的新日期

DATEDIFF(<datepart>,<number>,<date>)

--函数返回两个指定日期在datepart方面的不同之处

DATENAME(<datepart>,<date>) --函数以字符串的形式返回日期的指定部分

DATEPART(<datepart>,<date>) --函数以整数值的形式返回日期的指定部分

GETDATE() --函数以DATETIME的缺省格式返回系统当前的日期和时间

----系统函数----

APP_NAME() --函数返回当前执行的应用程序的名称

COALESCE() --函数返回众多表达式中第一个非NULL表达式的值

COL_LENGTH(<'table_name'>,<'column_name'>) --函数返回表中指定字段的长度值

COL_NAME(<table_id>,<column_id>) --函数返回表中指定字段的名称即列名

DATALENGTH() --函数返回数据表达式的数据的实际长度

DB_ID(['database_name']) --函数返回数据库的编号

DB_NAME(database_id) --函数返回数据库的名称

HOST_ID() --函数返回服务器端计算机的名称

HOST_NAME() --函数返回服务器端计算机的名称

IDENTITY(<data_type>[,seed increment]) [AS column_name])

--IDENTITY()函数只在SELECT INTO语句中使用用于插入一个identity column列到新表中

/*select identity(int, 1 , 1)as column_nameinto newtablefrom oldtable*/

ISDATE() --函数判断所给定的表达式是否为合理日期

ISNULL(<check_expression>,<replacement_value>) --函数将表达式中的NULL值用指定值替换

ISNUMERIC() --函数判断所给定的表达式是否为合理的数值

NEWID() --函数返回一个UNIQUEIDENTIFIER类型的数值

NULLIF(<expression1>,<expression2>)

--NULLIF函数在expression1与expression2相等时返回NULL值若不相等时则返回expression1的值

欧路云(22元/月),美国CERA弹性云服务器!香港弹性云服务器15元/月起;加拿大高防vps仅23元/月起

欧路云怎么样?欧路云主要运行弹性云服务器,可自由定制配置,可选加拿大的480G超高防系列,也可以选择美国(200G高防)系列,也有速度直逼内地的香港CN2系列。所有配置都可以在下单的时候自行根据项目 需求来定制自由升级降级 (降级按天数配置费用 退款回预存款)。2021年7月14日美国 CERA 弹性云服务器 上新 联通CUVIP 线路!8折特惠中!点击进入:欧路云官方网站地址付款方式:PayPa...

racknerd:美国大硬盘服务器(双路e5-2640v2/64g内存/256gSSD+160T SAS)$389/月

racknerd在促销美国洛杉矶multacom数据中心的一款大硬盘服务器,用来做存储、数据备份等是非常划算的,而且线路还是针对亚洲有特别优化处理的。双路e5+64G内存,配一个256G的SSD做系统盘,160T SAS做数据盘,200T流量每个月,1Gbps带宽,5个IPv4,这一切才389美元...洛杉矶大硬盘服务器CPU:2 * e5-2640v2内存:64G(可扩展至128G,+$64)硬...

台湾CN2云服务器 2核2G 5M 5IP 台湾物理服务器 E5x2 64G 20M 5IP

提速啦(www.tisula.com)是赣州王成璟网络科技有限公司旗下云服务器品牌,目前拥有在籍员工40人左右,社保在籍员工30人+,是正规的国内拥有IDC ICP ISP CDN 云牌照资质商家,2018-2021年连续4年获得CTG机房顶级金牌代理商荣誉 2021年赣州市于都县创业大赛三等奖,2020年于都电子商务示范企业,2021年于都县电子商务融合推广大使。资源优势介绍:Ceranetwo...

sql语句大全为你推荐
缓冲区溢出教程溢出攻击法使用什么样的原理ghostxp3目前最好的ghost xp3是什么?伪静态什么是伪静态ps抠图技巧请教PS抠图技巧!!!淘宝店推广如何推广淘宝店安卓应用平台app应用平台有哪些 应用平台哪些中小企业信息化信息化为中小企业发展带来了哪些机遇腾讯文章怎样才能在手机腾讯网上发表文章?qq怎么发邮件用QQ怎样发送文件数据库损坏数据库坏了怎么办
深圳域名空间 免费com域名申请 simcentric sugarsync godaddy域名转出 100x100头像 个人域名 酷番云 东莞服务器 备案空间 重庆电信服务器托管 贵阳电信 万网空间 广州主机托管 winserver2008r2 WHMCS 服务器机柜 gotoassist 企业私有云存储 ftp服务器架设 更多