SQL_Server_2005_函数大全
sqlserver2005 concat函数 -回复
sqlserver2005 concat函数-回复SQL Server 2005中的CONCAT函数在SQL Server 2005中,我们可以使用CONCAT函数来将多个字符串合并为一个字符串。
CONCAT函数在SQL Server 2012中引入,但在2005版本中也可以使用。
本文将介绍CONCAT函数的使用方法,并提供一些示例来帮助读者更好地理解。
第一步:了解CONCAT函数的语法CONCAT函数的语法非常简单,它接受任意多个字符串作为参数,并返回这些字符串的连接结果。
它的基本语法如下:CONCAT (string1, string2 [, string3, ...])参数string1、string2、string3等都是要连接的字符串。
CONCAT函数会按照参数的顺序将它们连接在一起,并返回一个新的字符串。
需要注意的是,CONCAT函数可以接受任意多个字符串作为参数,但至少需要提供两个参数。
第二步:使用CONCAT函数进行字符串拼接使用CONCAT函数进行字符串拼接非常简单。
以下是一个简单的示例:SELECT CONCAT('Hello', ' ', 'World') AS ConcatenatedString;上述查询将返回结果为"Hello World"的一列。
在这个示例中,我们提供了三个参数,它们之间用空格分隔。
CONCAT函数将这三个参数连接在一起,并返回新的字符串。
除了字符串常量之外,我们还可以使用列或变量来作为CONCAT函数的参数。
以下是一个使用列和变量的示例:DECLARE @FirstName VARCHAR(20) = 'John';DECLARE @LastName VARCHAR(20) = 'Doe';SELECT CONCAT(@FirstName, ' ', @LastName) AS FullName;在上面的示例中,我们定义了两个变量@FirstName和@LastName,并将它们的值分别设置为"John"和"Doe"。
sql server 2005数据库查询
8.1 数据库查询 8.2 数据汇总 8.3 排序 8.4 分组
8.1 数据库查询
SELECT [ALL|DISTINCT] [ TOP <operator> ]
[<column_name >] [AS< column_name >] [, [<column_name >] <Select operator >[AS < column_name >]…] FORM[<database_name >] < table_name >[[AS]Local_Alias] [[INNER | LEFT [OUTER] | RIGHT [OUTER] | FULL [OUTER] JOIN[ <database_name>] <table_name> [[AS]Local_Alias][ON<联接条件> ]] [INTO <select> |TO FILE <file_name> [ADDITIVE] | TO PRINTER [PROMPT] | TO SCREEN]
8.1 数据库查询
SQL连接方式又分为内连接(默认), 外连接, 交叉连接(笛卡尔积)。 其语法格式如下:
[ INNER | { LEFT | RIGHT | FULL } [ OUTER ] [ CROSS ][ <join_hint> ] JOIN
【例】查询学生选修的课程的情况,输出学号和 【例】查询学生选修的课程的情况,输出姓名 课程名,如果有课程没有学生选修,也输出。 和课程号,如果有学生没有选修课程,也输出。 SELECT 学号,课程名 SELECT 姓名,课程号 FROM 课程表 LEFT JOIN 成绩表 FROM 成绩表 RIGHT JOIN 学生表 ON 课程表.课程号=成绩表.课程号 ON 学生表.学号=成绩表.学号
郝斌数据库SqlServer2005自学教程所有代码
用sql命令建表和约束create table dept(dept_id int primary key,dept_name nvarchar(100) not null,dept_address nvarchar(100))create table emp( --不能写成{emp_id int constraint pk_emp_id_hahaha primary key,emp_name nvarchar(20) not null,emp_sex nchar(1) ,dept_id int constraint fk_dept_id_heihei foreign key references dept(dept_id),)create table ttt(i int,j int)create table student(stu_id int primary key,stu_sal int check (stu_sal>=1000 and stu_sal<=8000),stu_sex nchar(1) default ('男') --()可以省在数据库中字符串是必须用''括起来的)insert into student(stu_id, stu_sal) values (1, 1000);insert into student values (2, 6000, '女');insert into student values (3, 6000, '女');insert into student values (4, 6000, '女');insert into student values (3, 6000);create table student2(stu_id int primary key,stu_sal int check (stu_sal>=1000 and stu_sal<=8000),stu_sex nchar(1) default ('男'), --()可以省在数据库中字符串是必须用''括起来的stu_name nvarchar(200) unique)insert into student2 values (1, 6000, '男', '张三'); --okinsert into student2 values (3, 6000, '男', '李四'); --okinsert into student2 values (null, 6000, '男', '王五'); --error 主键不能为null 出错的信息是“不能将值NULL 插入列'stu_id'”insert into student2 values (4, 6000, '男', null); --ok 说明唯一键允许为空insert into student2 values (5, 6000, '男', null);create table student3(stu_id int primary key,stu_sal int check (stu_sal>=1000 and stu_sal<=8000),stu_sex nchar(1) default ('男'), --()可以省在数据库中字符串是必须用''括起来的stu_name nvarchar(200) unique not null --uniqe和not null 约束可以组合是用)insert into student2 values (3, 6000, '男', null); --error 证明了: uniqe和not null 约束可以组合使用如何合理的利用主键和唯一键建表drop table student4; --删除student4create table student4(stu_id int primary key,stu_name nvarchar(50) unique not null,stu_email nvarchar(50) not null unique,stu_address nvarchar(50))oracle中的命令create table student2(stu_id int primary key,stu_sal int check (stu_sal>=1000 and stu_sal<=8000),stu_sex nchar(1) default ('男'), --()可以省在数据库中字符串是必须用''括起来的stu_name nvarchar2(200) unique)insert into student2 values (4, 6000, '男', null);insert into student2 values (5, 6000, '男', null);select * from student2复习create table student5(stu_email nvarchar(200) not null,stu_name nvarchar(20) unique,stu_sal int check (stu_sal>=1000 and stu_sal<=8000),stu_sex nchar(1) default '男')insert student5 values (1, 'hb.g@', 'zhangsan', 5000); --errorselect * from student5insert student5 (stu_id, stu_email, stu_name, stu_sal) values (2, 'hb.g@', 'zhangsan', 5000);insert student5 (stu_id, stu_email, stu_sal)values (3, 'hb.g@', 5000); --ok--这说明:stu_name默认是null 也就是说如果一个字段不写null 也不行not null 则默认是null 即默认允许为空用户可以不给该字段赋值多对多关系sql语句的实现--班级表create table banji(banji_id int primary key,banji_num int not null,banji_name nvarchar(100))--教师create table jiaoshi(jiaoshi_id int primary key,jiaoshi_name nvarchar(200))--第三张表用来模拟班级和教师的关系create table banji_jiaoshi_mapping(banji_id int constraint fk_banji_id foreign key references banji(banji_id),jiaoshi_id int foreign key references jiaoshi(jiaoshi_id),kecheng nvarchar(20),constraint pk_banji_id_jiaoshi_id primary key (banji_id, jiaoshi_id, kecheng))--删除表drop table banji_jiaoshi_mapping查询1select * from emp;-- * 表示所有的-- from emp 表示从emp表查询select empno, ename from emp;select ename, sal from emp;select ename, sal*12 as "年薪" from emp;--as 可以省略记住: "年薪" 不要写成'年薪' 也不要写成年薪select ename, sal*12 as "年薪", sal "月薪", job from emp;select 888 from emp;--ok--输出的行数是emp表的行数每行只有一个字段,值是888select 5; --ok--不推荐查询2select deptno from emp; --14行记录不是3行记录select distinct deptno from emp; --distince deptno 会过滤掉重复的deptnoselect distinct comm from emp; --distinct也可以过滤掉重复的null 或者说如果有多个null 只输出一个select distinct comm, deptno from emp;--把comm和deptno的组合进行过滤select deptno, distinct comm from emp;--error 逻辑上有冲突select 10000 from emp; --14行记录复习select * from emp;select ename from emp;select ename, * from emp; --ok 但是在Oracle11G中会出错,因此不建议这样写select ename as "姓名", sal from emp;select ename, 15 from emp;select 15; --不推荐select distinct deptno, comm from emp; -- ok 把deptno和comm的组合不重复的输出select distinct comm from emp; --okselect deptno, distinct comm from emp; --errorbetween查询示例--查找工资在1500到3000之间(包括1500和3000)的所有的员工的信息select * from empwhere sal>=1500 and sal<=3000等价于select * from empwhere sal between 1500 and 3000--查找工资在小于1500或大于3000之间的所有的员工的信息select * from empwhere sal<1500 or sal>3000等价于select * from empwhere sal not between 1500 and 3000select * from emp where sal in (1500, 3000, 5000)等价于select * from empwhere sal=1500 or sal=3000 or sal=5000in查询示例select * from emp where sal not in (1500, 3000, 5000) --把sal既不是1500 也不是3000也不是5000的记录输出等价于select * from empwhere sal<>1500 and sal<>3000 and sal<>5000--数据库中不等于有两种表示:!= <> 推荐使用第二种--对或取反是并且对并且取反是或top查询示例select * from emp;select top 5 * from emp;select top 15 percent * from emp; --输出的是3个,不是2个--把工资在1500到3000之间(包括1500和3000)的员工中工资最高的前4个人的信息输出select top 4 *from empwhere sal between 1500 and 3000order by sal desc --desc降序不写则默认是升序null查询示例select * from emp;--输出奖金非空的员工的信息select * from emp where comm <> null; --输出为空errorselect * from emp where comm != null; --输出为空errorselect * from emp where comm = null;--输出为空error--总结:null不能参与<> != =运算--null可以参与is not isselect * from emp where comm is null; --输出奖金为空的员工的信息select * from emp where comm is not null; --输出奖金不为空的员工的信息--任何类型的数据都允许为nullcreate table t1 (name nvarchar(20), cnt int, riqi datetime);insert into t1 values (null, null, null)select * from t1;select * from emp;--输出每个员工的姓名年薪(包含了奖金) comm假设是一年的奖金select empno, ename, sal*12+comm "年薪" from emp;--本程序证明了:null不能参与任何数据运算否则结果永远为空复习select top 5 from emp;select * from emp where comm is not nullselect ename, sal*12+comm from emp;select ename, sal*12+isnull(comm, 0) "年薪" from emp;--isnull(comm, 0) 如果comm是null 就返回零否则返回comm的值select * from emp where ename like '%A%' --ename只要含有字母A就输出select * from emp where ename like 'A%' --ename只要首字母是A的就输出select * from emp where ename like '%A' --ename只要尾字母是A的就输出select * from emp where ename like '_A%' --ename只要第二个字母是A的就输出select * from emp where ename like '_[A-F]%' --把ename中第二个字符是A或B或C或D或E或F的记录输出select * from emp where ename like '_[^A-F]%' --把ename中第二个字符不是A也不是B也不是C也不是D也不是E也不是F的记录输出select * from emp where ename like '_[^A-F]%' --把ename中第二个字符不是A也不是B也不是C也不是D也不是E也不是F的记录输出create table student(name varchar(20) null,age int);insert into student values ('张三', 88);insert into student values ('Tom', 66);insert into student values ('a_b', 22);insert into student values ('c%d', 44);insert into student values ('abc_fe', 56);insert into student values ('haobin', 25);insert into student values ('HaoBin', 88);insert into student values ('c%', 66)insert into student values ('long''s', 100)select * from student;select * from student where name like '%\%%' escape '\' --把name中包含有%的输出select * from student where name like '%\_%' escape '\' --把name中包含有_的输出--asc是升序的意思默认可以不写desc是降序select * from emp order by sal; --默认是按照升序排序select * from emp order by deptno, sal; --先按照deptno升序排序,如果deptno相同,再按照sal升序排序select * from emp order by deptno desc, sal;--先按deptno降序排序如果deptno相同再按照sal升序排序--记住sal是升序不是降序--order by a desc, b, c, d desc只对a产生影响不会对后面的b c d 产生影响select * from emp order by deptno, sal desc--问题:desc是否会对deptno产生影响?--答案:不会--先按deptno升序,如果deptno相同,再按sal降序聚合函数查询示例select lower(ename) from emp; -- 最终返回的是14行lower()是单行函数select max(sal) from emp; --返回1行max()是多行函数select * from emp;select count(*) from emp; --返回emp表所有记录的个数select count(deptno) from emp; --返回值是14 这说明deptno重复的记录也被当做有效的记录select count(distinct deptno) from emp; --返回值是3 统计deptno不重复的记录的个数select count(comm) from emp; --返回值是4 这说明comm为null的记录不会被当做有效的记录select max(sal) "最高工资", min(sal) "最低工资", count(*) "员工人数" from emp; --okselect max(sal), lower(ename) from emp;复习%_[a-f]select comm from emp;select max(sal), min(ename) from emp;select count(distinct comm) from emp;use scott;select * from emp;--输出每个部门的编号和该部门的平均工资select deptno, avg(sal) as "部门平均工资"from empgroup by deptno-- 判断下面语句是否正确select deptno, avg(sal) as "部门平均工资", enamefrom empgroup by deptno-- 判断下面语句是否正确select deptno, enamefrom empgroup by deptno总结:使用了group by 之后select 中只能出现分组后的整体信息,不能出现组内的详细信息group by a, b 的用法--errorselect deptno , job, salfrom empgroup by deptno, job--errorselect *from empgroup by deptno, job--okselect deptno , job, avg(sal)from empgroup by deptno, job--okselect deptno , job, avg(sal) "平均工资", count(*) "部门人数", sum(sal) "部门的总工资", min(sal) "部门最低工资"from empgroup by deptno, joborder by deptnoselect comm, count(*)from empgroup by commselect max(sal) from emp; --默认把所有的信息当做一组haivng 查询示例--输出部门平均工资大于2000的部门的部门编号部门的平均工资select deptno, avg(sal)from empgroup by deptnohaving avg(sal) > 2000--判断下列sql语句是否正确select deptno, avg(sal) as "平均工资"from empgroup by deptnohaving avg(sal) > 2000--判断下列sql语句是否正确select deptno, avg(sal) as "平均工资"from empgroup by deptnohaving "平均工资" > 2000--判断下列sql语句是否正确select deptno "部门编号", avg(sal) as "平均工资"from empgroup by deptnohaving deptno > 1--判断下列sql语句是否正确select deptno "部门编号", avg(sal) as "平均工资"from empgroup by deptnohaving "部门编号" > 1--判断下列sql语句是否正确select deptno, avg(sal) as "平均工资"group by deptnohaving deptno > 10--判断下列sql语句是否正确select deptno, avg(sal) as "平均工资"from empgroup by deptnohaving count(*) > 3--判断下列sql语句是否正确select deptno, avg(sal) as "平均工资"from empgroup by deptnohaving ename like '%A%'--把姓名不包含A的所有的员工按部门编号分组,--统计输出部门平均工资大于2000的部门的部门编号部门的平均工资select deptno, avg(sal) "平均工资"from empwhere ename not like '%A%'group by deptnohaving avg(sal) > 2000--把工资大于2000,--统计输出部门平均工资大于3000的部门的部门编号部门的平均工资select deptno, avg(sal) "平均工资", count(*) "部门人数", max(sal) "部门的最高工资"from empwhere sal > 2000 --where是对原始的记录过滤group by deptnohaving avg(sal) > 3000 --对分组之后的记录过滤--判断入选语句是否正确select deptno, avg(sal) "平均工资", count(*) "部门人数", max(sal) "部门的最高工资"from empgroup by deptnohaving avg(sal) > 3000 --对分组之后的记录过滤总计:所有select的参数的顺序是不允许变化的,否则编译时出错select * from emp;select count(*)from emphaving avg(sal) > 1000select ename, sal "工资"from empwhere sal > 2000select ename, sal "工资"from empwhere "工资" > 2000select deptno, avg(sal) "平均工资", count(*) "部门人数", max(sal) "部门的最高工资"into emp_2from empwhere sal > 2000 --where是对原始的记录过滤group by deptnohaving avg(sal) > 3000 --对分组之后的记录过滤select * from emp_2复习示例--输出部门编号部门的平均工资select deptno, avg(sal) "平均工资"from empgroup by deptno--errorselect *from empgroup by deptnoselect deptno, avg(sal) "平均工资", jobfrom empgroup by deptno--okselect deptno, avg(sal) "平均工资", count(*), sum(sal)from empgroup by deptno--okselect deptno, avg(sal) "平均工资", count(*) "部门人数", sum(sal) "部门工资总和"from empgroup by deptnohaving sum(sal) > 9000--error where子句不应该出现聚合函数select deptno, avg(sal) "平均工资", count(*) "部门人数", sum(sal) "部门工资总和"from empwhere avg(sal) > 2000 --error 因为where是对原始的数据过滤不能使用聚合函数因为还没有分组group by deptnohaving sum(sal) > 5000select deptno, job, count(*)from empwhere sal > 1000group by deptno, jobhaving count(*) > 1order by deptno descsql92 和sql99 标准比较查询示例--把工资大于2000的员工的姓名和部门的名称输出--sql92的实现方式select "E".ename, "D".dnamefrom emp "E", dept "D"where "E".sal > 2000 and "E".deptno = "D".deptno--sql99的实现方式select "E".ename, "D".dnamefrom emp "E"join dept "D"on "E".deptno = "D".deptnowhere "E".sal > 2000--把工资大于2000的员工的姓名和部门的名称输出和工资的等级--sql99标准明显的优于sql92select "E".ename, "D".dname, "S".gradefrom emp "E"join dept "D"on "E".deptno = "D".deptnojoin salgrade "S"on "E".sal>= "S".losal and "E".sal <= "S".hisalwhere "E".sal > 2000--把工资大于2000的员工的姓名和部门的名称输出和工资的等级--sql92标准select "E".ename, "D".dname, "S".gradefrom emp "E", dept "D", salgrade "S"where "E".sal > 2000 and "E".deptno = "D".deptno and ("E".sal>= "S".losal and "E".sal <= "S".hisal)--输出的是350行14列行数是乘积列数是之和select *from emp "E"join dept "D"on 1=1join salgrade "S"on 1=1select "E".ename, "D".dname, "S".gradefrom emp "E"where "E".sal > 2000 --error where不能卸载join的前面原因不得而知join dept "D"on "E".deptno = "D".deptnojoin salgrade "S"on "E".sal>= "S".losal and "E".sal <= "S".hisal内连接查询示例select "E".ename "员工姓名", "D".dname "部门名称"from emp "E"join dept "D"on "E".deptno = "D".deptno1.select ... from A, B的用法--emp是14行8 列dept是5行3列select * from emp, deptselect ... from A, B where ... 的用法--输出5行11列select *from emp, deptwhere empno = 73693.select ... from A join B on ... 的用法--输出11列70行select *from emp "E"join dept "D" --join是连接on 1=1 --on连接条件--输出2列70行select "E".ename "员工姓名", "D".dname "部门名称"from emp "E"join dept "D" --join是连接on 1=1 --on连接条件on不能省有join就必须有on--判断下面语句是否正确select deptnofrom emp "E"join dept "D" --join是连接on 1=1--判断下面语句是否正确select "部门表".deptno "部门编号"from emp "员工表"join dept "部门表" --join是连接on 1=1--考虑下面语句的输出结果是什么--答案:14行11列select *from emp "E"join dept "D" --join是连接on "E".deptno = "D".deptno--考虑下面语句的输出结果是什么--答案:14行2列select "E".ename "员工姓名", "D".dname "部门名称"from emp "E"join dept "D" --join是连接select *from emp, deptwhere emp.deptno = dept.deptno等价于select * from empjoin depton emp.deptno = dept.deptno复习上节课例子和习题讲解示例内连接--输出的行数肯定是dept表行数的倍数select * from emp, dept w here emp.deptno = 10--输出的行数肯定是emp表行数的倍数select * from emp, dept --7行where dept.deptno = 10 --过滤条件不是连接条件考虑如何把上面的sql语句用sql99来实现--这样写不对select *from empjoin depton emp.deptno = dept.deptno --也不对on中指定的是连接条件7行的连接条件是永远为真having dept.deptno = 10 --error 因为having是对分组之后的过滤这里没有分组肯定出错--这个sql语句和7行的sql语句输出结果是一模一样的select *from empjoin depton 1=1where dept.deptno = 10--输出姓名不包含A的所有员工中工资最高的前三名的每个员工的姓名工资工资等级部门名称select top 3 "E".ename, "E".sal, "S".grade, "D".dnamefrom emp "E"join dept "D"on "E".deptno = "D".deptnojoin salgrade "S"where "E".ename not like '%A%'order by "E".sal desc--输出部门名称不包含A的所有员工中工资最高的前三名的每个员工的姓名工资工资等级部门名称select top 3 "E".ename, "E".sal, "S".grade, "D".dnamefrom emp "E"join dept "D"on "E".deptno = "D".deptnojoin salgrade "S"on "E".sal between "S".losal and "S".hisalwhere "D".dname not like '%A%'order by "E".sal desc习题集第一个习题--求出每个员工的姓名部门编号薪水和薪水的等级select "E".ename, "E".deptno, "E".sal, "S".gradefrom emp "E"join salgrade "S"on "E".sal >= "S".losal and "E".sal <= "S".hisal第二个习题--查找每个部门的编号该部门所有员工的平均工资平均工资的等级select "T".deptno, "T"."avg_Sal" "部门平均工资", "S".grade "工资等级"from (select deptno, avg(sal) as "avg_sal"from empgroup by deptno) "T"join salgrade "S"on "T".avg_sal between "S".losal and "S".hisal等价于select "T".deptno, "T"."avg_Sal" "部门平均工资", "S".grade "工资等级"from salgrade "S"join (select deptno, avg(sal) as "avg_sal"from empgroup by deptno) "T"等价于select "T".deptno, "T"."avg_Sal" "部门平均工资", "S".grade "工资等级"from salgrade "S", (select deptno, avg(sal) as "avg_sal"from empgroup by deptno) "T"where "T".avg_sal between "S".losal and "S".hisal第三个习题查找每个部门的编号部门名称该部门所有员工的平均工资平均工资的等级select "T".deptno, "T"."avg_Sal" "部门平均工资", "S".grade "工资等级" , "D".dname "部门名称"from (select deptno, avg(sal) as "avg_sal"from empgroup by deptno) "T"join salgrade "S"on "T".avg_sal between "S".losal and "S".hisaljoin dept "D"on "T".deptno = "D".deptno第四个习题求出emp表中所有领导的信息select * from empwhere empno in (select mgr from emp)思考题求出emp表中所有非领导的信息select * from empwhere empno not in (select mgr from emp)in与null的组合所带来的问题第五个习题求出平均薪水最高的部门的编号和部门的平均工资--第一种写法select top 1 deptno "部门的编号",avg(sal)"平均工资"from empgroup by deptnoorder by avg(sal) desc--第二种写法from (select deptno, avg(sal) "avg_sal"from empgroup by deptno) "E"where "E"."avg_sal" = (select max("avg_sal") from (select deptno, avg(sal) "avg_sal" from emp group by deptno) "T")第六个习题有一个人工资最低把这个人排除掉剩下的人中工资最低的前3个人的姓名工资部门编号部门名称工资等级输出select top 3 "T".ename, "T".sal, "T".deptno, "D".dname, "S".gradefrom (select *from emp "E" --153行where sal > ( select min(sal) from emp )) "T" --这里的"E"与153行的"E"是没有冲突的,因为范围不一样join dept "D"on "T".deptno = "D".deptnojoin salgrade "S"on "T".sal between "S".losal and "S".hisalorder by "T".sal asc内连接总复习示例empdeptsalgradeselect * from emp, dept -- 70行11列select * from dept, emp -- 输出结果等价于select * from emp, deptselect * from emp, dept where 1=1 -- 70行11列where中写的过滤条件实际是对(emp, dept)产生的笛卡尔积临时表过滤select * from emp, dept where empno = 7369 --5行select * from emp, dept where deptno = 10; --errorselect * from emp, dept where emp.deptno = 10; --5行的倍数select * from emp, dept where dept.deptno = 10; --14行--本语句输出结果等价于select * from emp, dept where dept.deptno = 10;select *from empon 2=2where dept.deptno = 10;--输出70行11列select *from empjoin depton 1=1等价于select * from emp, dept等价于select * from dept, emp等价于select *from deptjoin empon 1=1--考虑下面语句的实际含义以及这样写是否恰当?select * from empjoin depton emp.deptno = dept.deptno and emp.sal>2000 --on中既可以写连接条件也可以写过滤条件但是不推荐应该分开写on中只写连接条件where中写过滤条件等价于select * from empjoin depton emp.deptno = dept.deptnowhere emp.sal>2000等价于select * from deptjoin empon dept.deptno = emp.deptnowhere emp.sal>2000等价于select *from dept,empwhere dept.deptno = emp.deptno and emp.sal>2000--error 有join就必须的有onselect * from empjoin dept查询的顺序select top ....join Bon ....join Con ....where ......group by ...having .....order by .....--把工资大于1500的所有的员工按部门分组把部门平均工资大于2000的最高前2个的部门的编号部门的名称部门平均工资的等级--第一种写法select "T".*, "D".dname, "S".gradefrom dept "D"join (select top 2 "E".deptno, avg(sal) "avg_sal"from emp "E"join dept "D"on "E".deptno = "D".deptnojoin salgrade "S"on "E".sal between "S".losal and "S".hisalwhere "E".sal > 1500group by "E".deptnohaving avg("E".sal) > 2000order by avg("E".sal) desc) "T"on "D".deptno = "T".deptnojoin salgrade "S"on "T"."avg_sal" between "S".losal and "S".hisal--第二种写法select "T".*, "D".dname, "S".gradefrom dept "D"inner join (select top 2 deptno, avg(sal) as "avg_sal"from empwhere sal > 1500group by deptnohaving avg(sal) > 2000order by "avg_sal" desc) "T"on "D".deptno = "T".deptnoinner join salgrade "S"on "T"."avg_sal" between "S".losal and "S".hisal左外连接查询示例select * from emp "E"left join dept "D"on E.deptno = D.deptnoselect * from dept "D"left join emp "E"on E.deptno = D.deptnoselect * from dept;自连接查询示例用聚合函数求薪水最高的员工的信息select * from emp where sal = (select max(sal) from emp)不准用聚合函数求薪水最高的员工的信息select * from empwhere empno not in (select distinct "E1".empnofrom emp "E1"join emp "E2"on "E1".sal< "E2".sal)联合查询示例输出每个员工的姓名工资上司的姓名select "E1".ename, "E1".sal, "E2".ename "上司的姓名"from emp "E1"join emp "E2"on "E1".mgr = "E2".empnounionselect ename, sal, '已是最大老板' from emp where mgr is null select * from emp;分页查询示例select top 3 * from emporder by sal ascselect top 3 * from emporder by sal ascidentitycreate table student2(student_id int primary key, --必须的为student_id赋值student_name nvarchar(200) not null)select * from student2;insert into student2 values (1, '张三');insert into student2 values (2, '李四');insert into student2 values (1, '张三'); --errorinsert into student2 values ( '张三'); --errorinsert into student2(student_name) values ('张三');--errorcreate table student3(student_id int primary key identity(100, 5), --必须的为student_id赋值student_name nvarchar(200) not null)select * from student3insert into student3 (student_name) values ('张三');insert into student3 values ('李四') --okdelete from student3 where student_name = '李四';insert into student3 (student_name) values ('王五');事务create table bank(customerEname nvarchar(200),currentMoney money)select * from bank;delete from bank;insert into bank values ('张三', 1000);insert into bank values ('李四', 1);alter table bank add constraint check_currentMoney check(currentMoney>=1)update bank set currentMoney=currentMoney-1000 where customerEname='张三' update bank set currentMoney=currentMoney+1000 where customerEname='李四'begin transactiondeclare @errorSum intset @errorSum = 0update bank set currentMoney=currentMoney-1000where customerEname='张三'set @errorSum = @errorSum + @@errorupdate bank set currentMoney=currentMoney+1000where customerEname='李四'set @errorSum = @errorSum + @@errorif (@errorSum <> 0)beginprint '转账失败'rollback transactionendelsebeginprint '转账成功'commit transactionend转账事务操作源代码create database Testuse Testcreate table bank(customerEname nvarchar(200),currentMoney money)insert into bank values ('张三', 1000)insert into bank values ('李四', 1)alter table bank add constraint check_currentMoney check(currentMoney>=1)update bank set currentMoney=currentMoney-1000 where customerEname='张三' update bank set currentMoney=currentMoney+1000 where customerEname='李四'begin transactiondeclare @errorSum intset @errorSum = 0update bank set currentMoney=currentMoney-1000where customerEname='张三'set @errorSum = @errorSum + @@errorupdate bank set currentMoney=currentMoney+1000where customerEname='李四'set @errorSum = @errorSum + @@errorif (@errorSum <> 0)beginprint '转账失败'rollback transactionendelsebeginprint '转账成功'commit transactionend视图查询示例求出平均工资最高的部门的编号和部门的平均工资select *from (select deptno, avg(sal) "avg_sal"from empgroup by deptno) "T"where "T"."avg_sal" = (select max("E"."avg_sal") from (select deptno, avg(sal) "avg_sal"from empgroup by deptno) "E")create view v$_emp_1asselect deptno, avg(sal) "avg_sal"from empgroup by deptnoselect * from v$_emp_1where avg_sal = (select max(avg_sal) from v$_emp_1)select deptno, avg(sal) "avg_sal"from empgroup by deptnoselect * from emp;create view v$_emp2asselect empno, ename, job, mgr, comm, deptno from empselect * from v$_emp2--errorcreate view v$_aasselect avg(sal) from emp; --okcreate view v$_aasselect avg(sal) as "avg_sal" from emp;create table tt(字段名字数据类型,字段名字数据类型,字段名字数据类型,...............)create view tt2asselect...........分页查询示例select * from emp;输出工资最高的前三个员工的所有的信息select top 3 * from emp order by sal desc; --从输出结果来看先执行order by 后执行top工资从高到低排序,输出工资是第4-6的员工信息select top 3 *from empwhere empno not in (select top 3 empno from emp order by sal desc)order by sal desc工资从高到低排序,输出工资是第7-9的员工信息select top 3 *from empwhere empno not in (select top 6 empno from emp order by sal desc)order by sal desc工资从高到低排序,输出工资是第10-12的员工信息select top 3 *。
SQL Server 2005
1 基本SELECT语句
1.1 投影查询 1.2 条件查询
1.1 投影查询
最基本的 SELECT 语句仅有两个部分:要返回的列,和这些 列源于的表。也就是说查询均为不使用WHERE子句的无条件 查询,也称作投影查询。 例1-1 从读者类型中查询类型,图书册数,期刊册数,续借次数, 限制图书,限制期刊。 程序清单如下: select 类型,图书册数,期刊册数,续借次数,限制图书,限制期刊 from 读者类型 例1-2 查询读者类型中的全部信息。 程序清单如下: select * from 读者类型 注意:用‘ * ’表示表的全部列名,而不必逐一列出。
例1-27 在分组查询中使用HAVING条件,查询平均成 绩大于85的学生学号及平均成绩。 程序清单如下: SELECT sno, AVG(score) AS 'AverageScore' FROM sc GROUP BY sno HAVING AVG(score) >85 GO 注意:如果 HAVING 中包含多个条件,那么这些条件 将通过 AND、OR 或 NOT 组合在一起
2.1 聚合函数和GROUP BY子句
GROUP BY子句可以将查询结果按属性列或属性列组合在行的 方向上进行分组,每组在属性列或属性列组合上具有相同的聚合 值。如果聚合函数没有使用 GROUP BY 子句,则只为 SELECT 语句报告一个聚合值。常用的聚合函数,如表1-3所示。
表1-3常用的聚合函数
注意:在SELECT语句中可利用“IN”操作来查询属性值属于 指定集合的元组。利用“NOT IN”可以查询指定集合外的元组。 如下面两个例子。 例 查询选修C1或C2的学生的学号、课程号和成绩。 程序清单如下: SELECT SNO, CNO, SCORE FROM SC WHERE CNO IN(„C1‟, „C2‟)
Sql四大排名函数(ROW_NUMBER、RANK、DENSE_RANK、NTILE)简介
Sql四⼤排名函数(ROW_NUMBER、RANK、DENSE_RANK、NTILE)简介排名函数是Sql Server2005新增的功能,下⾯简单介绍⼀下他们各⾃的⽤法和区别。
我们新建⼀张Order表并添加⼀些初始数据⽅便我们查看效果。
CREATE TABLE [dbo].[Order]([ID] [int] IDENTITY(1,1) NOT NULL,[UserId] [int] NOT NULL,[TotalPrice] [int] NOT NULL,[SubTime] [datetime] NOT NULL,CONSTRAINT [PK_Order] PRIMARY KEY CLUSTERED([ID] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY]GOSET IDENTITY_INSERT [dbo].[Order] ONGOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (1, 1, 100, CAST(0x0000A419011D32AF AS DateTime))GOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (2, 2, 500, CAST(0x0000A419011D40BA AS DateTime))GOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (3, 3, 300, CAST(0x0000A419011D4641 AS DateTime))GOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (4, 2, 1000, CAST(0x0000A419011D4B72 AS DateTime))GOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (5, 1, 520, CAST(0x0000A419011D50F3 AS DateTime))GOINSERT [dbo].[Order] ([ID], [UserId], [TotalPrice], [SubTime]) VALUES (6, 2, 2000, CAST(0x0000A419011E50C9 AS DateTime))GOSET IDENTITY_INSERT [dbo].[Order] OFFGOALTER TABLE [dbo].[Order] ADD CONSTRAINT [DF_Order_SubTime] DEFAULT (getdate()) FOR [SubTime]GO 附上表结构和初始数据图:⼀、ROW_NUMBER row_number的⽤途的⾮常⼴泛,排序最好⽤他,⼀般可以⽤来实现web程序的分页,他会为查询出来的每⼀⾏记录⽣成⼀个序号,依次排序且不会重复,注意使⽤row_number函数时必须要⽤over⼦句选择对某⼀列进⾏排序才能⽣成序号。
SQL Server 2005基础知识整理
SQL Server 2005基础知识整理1. ACID:指数据库事务正确执行的四个基本要素缩写:1.原子性2.一致性3.隔离性4.持久性2.数据库对象:表(table)视图(view)存储过程(stored procedure)函数(function)索引(index)3.SQL Server 2005中包含master、model、msdb、tempdb四个系统数据库。
4.使用T-SQL语句创建数据库:CREATE DATABASE [ApressFinacial] ON PRIMARY( NAME = N'ApressFinacial', FILENAME = N'I:\Program Files\Microsoft SQL Server\MSS QL.1\MSSQL\DATA\ApressFinacial.mdf' , SIZE = 3072KB , FILEGROWTH = 1024KB )LOG ON( NAME = N'ApressFinacial_log', FILENAME = N'I:\Program Files\Microsoft SQL Server\ MSSQL.1\MSSQL\DATA\ApressFinacial_log.ldf' , SIZE = 1024KB , FILEGROWTH = 10 %)5.T-SQL语句删除数据库:drop database[数据库名]6.常见的约束类型:主键约束、唯一约束、检查约束、默认约束、外键约束。
7.添加约束的语法:Alter table 表名Add constraint 约束名约束类型具体的约束说明8.删除约束:alter table 表名Drop constraint 约束名9.授权语法: grant 权限[on 表名] to 数据库用户例:grant select insert updateOn students to zhangsan10.T-SQL语句创建登录名:Create login[yuan]With password='130125'Go11.数据库完整性分为:实体完整性、域完整性、参照完整性、用户自定义完整性。
SQL Server 2005的字符串函数
SQL Server 2005的字符串函数简介:下面的一组技巧会演示SQL Server 2005的字符串函数。
字符串函数对T-SQL编程非常有用,能让我们进行字符串清除、ASCII和普通字符之间的转换、模式搜索、移除尾部空格等等。
关键词:下面的一组技巧会演示SQL Server 2005的字符串函数。
字符串函数对T-SQL 编程非常有用,能让我们进行字符串清除、ASCII和普通字符之间的转换、模式搜索、移除尾部空格等等。
表8-3列出了SQL Server 2005中提供的各种字符串函数。
表8-3 字符串函数函数名描述ASCII和CHAR ASCII函数接受字符表达式最左边的字符并返回ASCII码。
CHAR函数把ASCII码的整数值转化为字符值CHARINDEX和PATINDEXCHARINDEX函数用于返回一个字符串在另外一个字符串中的起始位置。
PATINDEX函数和CHARINDEX相似,只是PATINDEX允许在指定要搜索的字符串的时候使用通配符DIFFERENCE和SOUNDEXDIFFERENCE和SOUNDEX都用于计算发音相似的字符串。
SOUNDEX为字符串分配一个4位数字码,DIFFERENCE计算两个独立字符串的SOUNDEX输出的相似级别LEFT和RIGHT LEFT函数返回字符串从左起指定个字符数的一部分字符串。
RIGHT函数和LEFT函数相似,只是返回字符串从右起指定个字符数的一部分字符串LEN和DATALENGTHLEN函数返回字符串表达式的字符个数,不包括最后一个字符后面的任何空格(尾部空格)。
而DATALENGTH返回表达式使用的字节数LOWER和UPPER LOWER函数返回字符表达式的小写形式,UPPER函数返回字符表达式的大写形式LTRIM和RTRIM LTRIM函数移除前导空格,RTRIM函数移除尾部空格NCHAR和UNICODEUNICODE函数返回字符表达式或输入表达式的第一个字符的Unicode整数值。
SQLServer常用函数及命令
SQLServer常⽤函数及命令1.字符串函数--ascii函数,返回字符串最左侧字符的ascii码值SELECT ASCII('a') AS asciistr--ascii代码转换函数,返回指定ascii值对应的字符SELECT CHAR(97) AS strs--left(c1,n)左⼦串函数,返回字符串c1中从左边开始的n个字符SELECT LEFT('helloworld',4) AS lefts--len(c1)返回字符串c1的字符(⽽不是字节)数,其中不包含尾随空格SELECT LEN('helloworld') AS lens--lower(c1) ⼤写转换为⼩写SELECT LOWER('HELLOWORLD') AS lowers--LTRIM(c1)删除前导空格,返回删除了前导空格的字符串 ltrim()去左边空格(rtrim()右边空格)SELECT LTRIM(' asafas') AS lt--REPLACE(C1,C2,C3) 替换字符函数SELECT REPLACE('ZHESSDF-DFDSS','-','@') AS RE--REPLICATE(C1,N)复制函数,以指定的次数n重复字符串c1SELECT REPLICATE('这是复制函数-',3) AS rep--right(c1,n)右⼦串函数,返回字符串c1中从右边开始的n个字符串SELECT RIGHT('asdfggh',4) AS strs--space(n) 空格函数,返回由n个重复的空格字符串SELECT SPACE(7) AS spaces--str(f,n,m)返回由数值数据f转换来的字符串,字符串的长度有参数n决定,字符串中保留的⼩数位书由M决定SELECT STR(12.1234,9,6) AS strs--SUBSTRING(c1,n1,n2)求⼦串函数,返回字符串c1从n1开始,长度为n2的⼦串SELECT SUBSTRING('mylightshina',4,5)--upper(c1) 转⼤写SELECT UPPER('asdff') AS up--ISNULL('内容',''):判断字符串是否为null,是的话返回‘’2.⽇期函数--时间⽇期SELECT'today''s date is '+CONVERT(VARCHAR(12), GETDATE(),102)AS daSELECT GETDATE() 当前⽇期时间,GETUTCDATE() ut⽇期时间,DATEPART(YEAR, GETDATE()) 年,DATENAME(YEAR, GETDATE()) 年名,DATEPART(MONTH, GETDATE()) ⽉,DATENAME(MONTH, GETDATE()) ⽉份名,DATEPART(DAY, GETDATE()) ⽇,DAY(GETDATE()) ⽇,MONTH(GETDATE()) ⽉,YEAR(GETDATE()) 年,DATEADD(DAY, 5, GETDATE()) 新⽇期,DATEDIFF(DAY, GETDATE(), '2018-12-17') AS⽇期间隔;3.系统函数--转换函数 cast(),convert()SELECT CAST('2018'AS DECIMAL(10, 5)) AS deci,CONVERT(VARCHAR, GETDATE(), 101) AS'101',CONVERT(VARCHAR, GETDATE(), 102) AS'102',CONVERT(VARCHAR, GETDATE(), 103) AS'103',CONVERT(VARCHAR, GETDATE(), 104) AS'104',CONVERT(VARCHAR, GETDATE(), 105) AS'105',CONVERT(VARCHAR, GETDATE(), 106) AS'106',CONVERT(VARCHAR, GETDATE(), 107) AS'107',CONVERT(VARCHAR, GETDATE(), 108) AS'108',CONVERT(VARCHAR, GETDATE(), 109) AS'109',CONVERT(VARCHAR, GETDATE(), 100) AS'100',CONVERT(VARCHAR, GETDATE(), 120) AS'120',CONVERT(VARCHAR, GETDATE(), 121) AS'121',CONVERT(VARCHAR, GETDATE(), 126) AS'126',CONVERT(VARCHAR, GETDATE(), 130) AS'130';--创建uniqueidentifier类型的唯⼀值SELECT NEWID() AS Id--ISNULL(c1,c2)SELECT ISNULL(ParentId,'########'),*FROM dbo.Module--isdate(exp)判断exp是否为有效⽇期SELECT ISDATE('2018-12-11 12:2:1')--ISNUMERIC(c1)判断c1是否是数字,是则返回1,否返回0SELECT ISNUMERIC('1') 是,ISNUMERIC('a') 否4.流程控制语句--begin...end语句块BEGINSELECT*FROM dbo.Role;END;--if...else语句IF1>4SELECT*FROM dbo.Role;ELSESELECT*FROM dbo.FlowInstance;--简单case表达式SELECT CASE ActivityType WHEN2THEN'qqq'ELSE'www'END ss ,*FROM dbo.FlowInstance--搜索case表达式SELECT CASE WHEN ActivityType>2THEN'qqq'ELSE'www'END ss ,*FROM dbo.FlowInstance--waitfor语句WAITFOR DELAY '00:00:03';SELECT*FROM dbo.Role;--在下午⼋点查询输出WAITFOR TIME '20:00:00';SELECT*FROM dbo.Form;--while语句DECLARE@sum INT,@i INT;SET@i=0;SET@sum=0;WHILE@i<=100BEGINSET@i=@i+1;IF ((@i%2) =0)CONTINUE;SET@sum=@sum+@i;IF (@i>50)BREAK;END;PRINT'1-50中的奇数和为'+CONVERT(CHAR(6), @sum);5.sp命令1、数据库:--sp_helpdb:报告有关指定数据库或所有数据库的信息。
SQL Server系统函数大全
sql server 系统函数大全一、字符转换函数1、ASCII()返回字符表达式最左端字符的ASCII 码值。
在ASCII()函数中,纯数字的字符串可不用‘’括起来,但含其它字符的字符串必须用‘’括起来使用,否则会出错。
2、CHAR()将ASCII 码转换为字符。
如果没有输入0 ~ 255之间的ASCII 码值,CHAR()返回NULL 。
3、LOWER()和UPPER()LOWER()将字符串全部转为小写;UPPER()将字符串全部转为大写。
4、STR()把数值型数据转换为字符型数据。
STR (<float_expression>[,length[,<decimal>]])length 指定返回的字符串的长度,decimal 指定返回的小数位数。
如果没有指定长度,缺省的length 值为10,decimal 缺省值为0。
当length 或者decimal 为负值时,返回NULL;当length 小于小数点左边(包括符号位)的位数时,返回length 个*;先服从length ,再取decimal ;当返回的字符串位数小于length ,左边补足空格。
二、去空格函数1、LTRIM() 把字符串头部的空格去掉。
2、RTRIM() 把字符串尾部的空格去掉。
三、取子串函数1、left()LEFT (<character_expression>,<integer_expression>)返回character_expression 左起integer_expression 个字符。
2、RIGHT()RIGHT (<character_expression>,<integer_expression>)返回character_expression 右起integer_expression 个字符。
3、SUBSTRING()SUBSTRING (<expression>,<starting_ position>,length)返回从字符串左边第starting_ position 个字符起length个字符的部分。
SQLServer 2005日期函数
1 SQL Server 有两种日期类型:DATETIME 和 SMALLDATETIME,DATETIME 的日期范围:1753-1-1到9999-12-31之间的日期值,精度为 3.33毫秒,其类型的值在SQLServer内部用两个 4 字节的整数存储。
第一个 4 字节存储“基础日期”(即 1900 年 1 月 1 日)之前或之后的天数。
基础日期是系统参照日期。
另外一个 4 字节存储天的时间(以午夜后经过的毫秒数表示)。
SMALLDATETIME的范围:1900-1-1到2079-6-6之间的日期值,精度为1分钟,其类型的值在SQLServer 内部用两个 2 字节的整数存储。
第一个 2 字节存储 1900 年 1 月 1 日后的天数。
另外一个 2 字节存储午夜后经过的分钟数2 SQL Server 获得当前日期的函数: GETDATE() GETUTCDATE() CURRENT_TIMESTAMPGETDATE(): 返回当前系统日期和时间GETUTCDATE(): 使用 DT_DBTIMESTAMP 格式返回以 UTC 时间(通用协调时间或格林尼治标准时间)表示的系统当前日期CURRENT_TIMESTAMP: 返回当前日期的和时间,等价于GETDATE()函数.注此函数不带括号"()"-------------------------------------------------------------------------------------------------------------------- SELECt GETDATE() AS [GETDATE],CURRENT_TIMESTAMP AS [CURRENT_TIMESTAMP],GETUTCDATE() AS [GETUTCDATE] ------ 返回结果:GETDATE CURRENT_TIMESTAMP GETUTCDATE ------ 2008-12-04 18:28:50.437 2008-12-04 18:28:50.437 2008-12-04 10:28:50.437 --------------------------------------------------------------------------------------------------------------------3 SQL Server 日期抽取函数: DATEPART DATENAME DAY MONTH YEARDATENAME: 返回表示指定日期的指定日期部分的字符串语法:DATENAME ( datepart ,date ) 注:datepart 是指定要返回的日期部分的参数DATEPART: 返回表示指定日期的指定日期部分的整数语法: DATEPART ( datepart ,date ) 注:datepart是指定要返回的日期部分的参数DAY: 返回一个整数,表示日期的“日”日期部分语法: DAY(date)MONTH: 返回一个整数,表示日期的“月”日期部门语法:MONTH(date)YEAR: 返回一个整数,表示日期的“年”日期部门语法:YEAR(date)注:DAY、MONTH、和 YEAR 函数分别是 DATEPART(dd, date)、DATEPART(mm, date) 和 DATEPART(yy, date) 的同义词,DAY、MONTH、YEAR比DATEPART和DATENAME更简洁4 SQL Server 日期的加减函数: DATEDIFF DATEADDDATEDIFF: 返回跨两个指定日期的日期边界数和时间边界数, 语法:DATEDIFF ( datepart , startdate , enddate ) 用 enddate 减去 startdate注:datepart 指定应在日期的哪一部分计算差额的参数,其日期相减时,只关注边界值,例SELECT DATEDIFF(YEAR,'2008-12-31','2009-1-1') 返回 1DATEADD : 返回给指定日期加上一个时间间隔后的新 datetime 值。
SQLserver2005学习笔记
数据库学习大纲目录数据库存储 (4)1.表的相关数据 (4)2.create table 命令 (4)3.什么是约束 (5)check约束 (5)default 约束 (5)唯一约束 (6)not null约束 (8)4.表和约束的异同 (8)5.什么是关系 (8)6.主键定义 (10)7.外键定义 (11)数据库查询 (11)1.计算列 (11)2.distinct【不允许重复的】 (12)3.between【在某个范围】 (12)4.in【属于若干个孤立的值】 (12)5.top【最前面的若干个记录专属于SqlServer的语法,不可移植到其他数据库】 (12)6.null【没有值空值】 (13)7.order by【以某个字段排序】 (13)8.模糊查询【搜索时经常使用】 (14)9.聚合函数【多行记录返回至一个值通常用于统计分组的信息】 (15)10.group by【分组难点】 (17)11.having【对分组之后的信息进行过滤难点】 (18)12.连接查询 (20)1.select ... from A, B 的用法 (21)2. select ... from A, B where ...的用法. (21)3. select ... from A join B on ... 的用法.. (22)4. select ... from A, B where ...与select ... from A join B on ...的比较.. (22)5. 习题集: (25)内连接复习小结: (27)查询的顺序 (29)13.外连接[参见ppt] (31)14.完全连接[参见ppt] (31)15.交叉连接[参见ppt] (31)16.自连接 (31)17.联合 (32)18.分页查询 (32)19.嵌套查询 (32)20.主键如何设置 (32)视图 (33)事务【重要参见ppt】 (35)分页查询 (36)什么是数据库SQL = = Structured Query Language结构化查询语言,第四代语言(1机器语言, 2汇编语言, 3 C系),主要用于对外存数据的存储和操作,由于其局限性(其中大多是命令),较复杂的功能实现不了,依赖于第三代语言来实现;第三代语言主要处理内存数据。
SQL Server 2005中的窗口函数
SQL Server 2005中的窗口函数帮助你迅速查看不同级别的聚合,通过它可以非常方便地累计总数、移动平均值、以及执行其它计算。
窗口函数功能非常强大,使用起来也十分容易。
可以使用这个技巧立即得到大量统计值。
窗口是用户指定的一组行。
开窗函数计算从窗口派生的结果集中各行的值。
2.适用范围:排名开窗函数和聚合开窗函数.也就是说窗口函数是结合排名开窗函数或者聚合开窗函数一起使用OVER子句前面必须是排名函数或者是聚合函数3.例题:--建立订单表create table SalesOrder(OrderID int, --订单idOrderQty decimal(18,2) --数量)go--插入数据insert into SalesOrderselect1,2.0union allselect1,1.0union allselect1,3.0union allselect2,6.0union allunion allselect3,8.0union allselect3,1.1union allselect3,7.0go--查询得如下结果select*from SalesOrdergoOrderID OrderQty----------- ------------1 2.001 1.001 3.002 6.002 1.1038.003 1.1037.00现要求显示汇总总数,每当所占比例,分组汇总数,每单在各组所占比例,要求格式如下:OrderID OrderQty 汇总每单比例分组汇总每单在各组比例1 2.00 29.20 0.0685 6.00 0.33331 1.00 29.20 0.0342 6.00 0.16671 3.00 29.20 0.1027 6.00 0.50002 6.00 29.20 0.2055 7.10 0.84512 1.10 29.20 0.0377 7.10 0.15493 8.00 29.20 0.2740 16.10 0.49693 1.10 29.20 0.0377 16.10 0.06833 7.00 29.20 0.2397 16.10 0.4348--利用窗口函数和聚合开窗函数,可以很快实现上述要求select OrderID,OrderQty,sum(OrderQty) over() as[汇总],convert(decimal(18,4), OrderQty/sum(OrderQty) over() ) as[每单所占比例],sum(OrderQty) over(PARTITION BY OrderID) as[分组汇总],convert(decimal(18,4),OrderQty/sum(OrderQty) over(PARTITION BY OrderID)) as[每单在各组所占比例]from SalesOrderorder by OrderID窗口函数是sql2005新增加的,下面我们看看在sql2000里面怎么实现上述的结果:sql2000的实现步骤较麻烦,先计算出总数,再分组计算汇总,最后连接得到结果--sql2000declare@sum decimal(18,2)select@sum=sum(OrderQty)from SalesOrder--按OrderID,计算每组的总计,然后插入临时表select OrderID,sum(OrderQty) as suinto #tfrom SalesOrdergroup by OrderID--连接临时表,得到结果select s.OrderID,s.OrderQty,@sum as[汇总],convert(decimal(18,4),s.OrderQty/@sum) as[每单所占比例],t.su as[分组汇总],convert(decimal(18,4),s.OrderQty/t.su) as[每单在各组所占比例]from SalesOrder s join #t ton t.OrderID=s.OrderIDorder by s.OrderIDdrop table #tgo上面演示的都是窗口函数与聚合开窗函数的使用,它与排名开窗函数请看下面例题:--与排名开窗函数使用select OrderID,OrderQty,rank() over(PARTITION BY orderid order by OrderQty ) as[分组排名],rank() over(order by OrderQty ) as[排名]from SalesOrderorder by orderid asc--查询得如下结果OrderID OrderQty 分组排名排名1 2.00241 3.00351 1.00112 1.1012 2 6.002637.002738.0038 3 1.1012。
sqlserver常用函数
1.字符串函数:len(expression)返回给定字符串表达式的字符(而不是字节)个数,其中不包含尾随空格。
datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格length(expression,variable)指定字符串或变量名称的长度。
substring(expression,start,length) 不多说了,取子串right(char_expr,int_expr) 返回字符串右边int_expr个字符concat(str1,str2,...)返回来自于参数连结的字符串。
datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格length(expression,variable)指定字符串或变量名称的长度。
substring(expression,start,length) 不多说了,取子串right(char_expr,int_expr) 返回字符串右边int_expr个字符concat(str1,str2,...)返回来自于参数连结的字符串。
字符操作类:upper(char_expr) 转为大写lower(char_expr) 转为小写UCase(string) 返回 Variant (String),其中包含转成大写的字符串。
LCase(string) 返回字符串的小写形式。
space(int_expr) 生成int_expr个空格replicate(char_expr,int_expr) 复制字符串int_expr次reverse(char_expr) 反转字符串stuff(char_expr1,start,length,char_expr2) 将字符串char_expr1中的从start开始的length个字符用char_expr2代替ltrim(char_expr) rtrim(char_expr) 去掉空格ascii(char) char(ascii) 两函数对应,取ascii码,根据ascii吗取字符字符串查找:charindex(char_expr,expression) 返回char_expr的起始位置patindex("%pattern%",expression) 返回指定模式的起始位置,否则为0 locate(substr,str,pos) 返回子串substr在字符串str第一个出现的位置2.数学函数abs(numeric_expr) 求绝对值ceiling(numeric_expr) 取大于等于指定值的最小整数exp(float_expr) 取指数floor(numeric_expr) 小于等于指定值得最大整数power(numeric_expr,power) 返回power次方rand([int_expr]) 随机数产生器round(numeric_expr,int_expr) 安int_expr规定的精度四舍五入sign(int_expr) 根据正数,0,负数,,返回+1,0,-1sqrt(float_expr) 平方根exp(float x):求e的x次幂tan(float x):计算x(弧度表示)的正切值。
2005提示row_number不是可以识别的函数名mssqlserv
2005 提示'row_number' 不是可以识别的函数名- MS-SQL Serv...ROW_NUMBER、RANK、DENSE_RANK的用法(爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开) 2007-12-16 广东深圳)SQL Server 2005 引入几个新的排序(排名)函数,如ROW_NUMBER、RANK、DENSE_RANK 等。
这些新函数使您可以有效地分析数据以及向查询的结果行提供排序值。
--------------------------------------------------------------------------ROW_NUMBER()说明:返回结果集分区内行的序列号,每个分区的第一行从1 开始。
语法:ROW_NUMBER () OVER ( [ ] order_by_clause> ) 。
备注:ORDER BY 子句可确定在特定分区中为行分配唯一ROW_NUMBER 的顺序。
参数:partition_by_clause> :将FROM 子句生成的结果集划入应用了ROW_NUMBER 函数的分区。
order_by_clause>:确定将ROW_NUMBER 值分配给分区中的行的顺序。
返回类型:bigint 。
示例:/*以下示例将根据年初至今的销售额,返回AdventureWorks 中销售人员的ROW_NUMBER。
*/USE AdventureWorksGOSELECT c.FirstName,stName, ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS 'Row Number', s.SalesYTD, a.PostalCodeFROM Sales.SalesPerson s JOIN Person.Contact c on s.SalesPersonID = c.ContactIDJOIN Person.Address a ONa.AddressID = c.ContactIDWHERE TerritoryID IS NOT NULL AND SalesYTD 0/*FirstName LastName Row Number SalesYTD PostalCode--------- ---------- ---------- ------------ ----------------------------Shelley Dyck 1 5200475.2313 98027Gail Erickson 2 5015682.3752 98055Maciej Dusza 3 4557045.0459 98027Linda Ecoffey 4 3857163.6332 98027Mark Erickson 5 3827950.238 98055Terry Eminhizer 6 3587378.4257 98055Michael Emanuel 7 3189356.2465 98055Jauna Elson 8 3018725.4858 98055Carol Elliott 9 2811012.7151 98027Janeth Esteves 10 2241204.0424 98055Martha Espinoza 11 1931620.1835 98055Carla Eldridge 12 1764938.9859 98027Twanna Evans 13 1758385.926 98055(13 行受影响)*//*以下示例将返回行号为50 到60(含)的行,并以OrderDate 排序。
sqlserver2005 concat函数
SQL Server 2005是微软推出的一款关系型数据库管理系统,该系统具有强大的功能和灵活的操作方式,在业界被广泛应用。
其中,concat函数是SQL Server 2005中十分重要的一个函数,它可以用于将多个字符串连接成一个字符串,为数据库操作提供了很大的便利。
在本文中,我们将深入探讨SQL Server 2005中concat函数的用法和实际应用。
一、concat函数的基本语法和功能在SQL Server 2005中,concat函数的基本语法如下:```CONCAT ( string_value1, string_value2 [, string_valueN ] )```其中,string_value1、string_value2等为要连接的字符串参数。
concat函数的功能是将这些字符串参数按顺序连接成一个新的字符串并返回。
二、concat函数的使用方法1. 基本用法```sqlSELECT CONCAT('Hello', ' ', 'World') AS ConcatenatedString;```通过以上示例可以看出,concat函数将参数中的字符串依次连接起来,生成新的字符串并返回。
2. 拼接表中的字段在实际的数据库操作中,我们常常需要对表中的字段进行拼接,concat函数也可以很好地满足这一需求。
```sqlSELECT CONCAT(FirstName, ' ', LastName) AS FullName FROM Users;```以上示例中,我们将Users表中的FirstName和LastName字段连接起来,生成新的FullName字段并返回。
3. 处理空值在实际操作中,表中的字段可能存在空值,为了避免出现结果中的空格和其他字符混在一起的情况,可以使用ISNULL函数处理空值。
```sqlSELECT CONCAT(ISNULL(FirstName, ''), ' ', ISNULL(LastName, '')) AS FullName FROM Users;```通过以上示例,我们对FirstName和LastName字段进行了空值处理,避免了结果中出现不必要的空格。
sql server 2005 函数分类
item 方法 返回集合中的当前项。
join 方法 返回一个由数组中的所有元素连接在一起的 String 对象。
lastIndexOf 方法 返回在 String 对象中子字符串最后出现的位置。
parseInt 方法 返回从字符串转换而来的整数。
pow 方法 返回一个指定幂次的底表达式的值。
2.字符串函数
atEnd 方法 返回一个表明枚举算子是否处于集合结束处的 Boolean 值。
big 方法 在String 对象的文本两端加入 HTML 的<BIG>标识。
blink 方法 将 HTML 的 <BLINK> 标识添加到 String 对象中的文本两端。
bold 方法 将 HTML 的 <B> 标识添加到String 对象中的文本两端。
ceil 方法 返回大于或等于其数值参数的最小整数。
charAt 方法 返回位于指定索引位置的字符。
charCodeAt 方法 返回指定字符的 Unicode 编码。
compile 方法 将一个正则表达式编译为内部格式。
getVarDate 方法 返回 Date 对象中的 VT_DATE。
getYear 方法 返回 Date 对象中的年份。
isFinite 方法 返回一个 Boolean 值,表明某个给定的数是否是有穷的。
isNaN 方法 返回一个 Boolean 值,表明某个值是否为保留值 NaN (不是一个数)。
setYear 方法 使用 Date 对象的年份。
toGMTString 方法 返回一个转换为使用格林威治标准时间(GMT)的字符串的日期。
SQL Server 2005 学习必备代码
SQL Server 2005 学习必备代码新建数据库代码create database ConstructionDB //新建数据库ConstructionDBon(name=ConstructionDB_dat, //数据库文件名filename="E:\数据库\ConstructionDB.mdf", //新建数据库的地址size=5,maxsize=25,filegrowth=1)log on(name=ConstructionDB_log, //新建数据库文件名filename="E:\数据库\ConstructionDB.ldf", //新建数据库的地址size=5,maxsize=25,filegrowth=1)Go新建表的代码:教材P55Create table 表名(字段名字符类型约束Pro_id varchar(18) not null primary key, --设置主键Prodect varchar(18) not null,Unitprice numeric(10,2)not null,Prounit varzhar(8) not null,Prodate datetime not null default getdate(), //设置默认值Protype varchar(20) null,Outdate datetime not null,)SQL Server 语句(增、删、查、改)//查询表stuinfo中全部的行和列SELECT * FROM stuinfo//查询表中性别为男的学生的姓名、学号、地址和性别SELECT stuNo,stuName,stuSex,stuAddress FROM stuinfo WHERE StuSex = '男'SELECT StuNo,StuName,stuSex,stuaddress FROM stuinfo WHERE StuSex <> '男'使用AS重新命名行和列SELECT StuNo AS 学生学号,stuName AS 学生姓名,stuAddress AS 学生地址FROM StudentsWHERE StuSex <> '男'SELECT FirstName+'.'+LastName AS '姓名'FROM Employee使用"="来命名SELECT '姓名' = FirstName+'.'+LastNameFROM Employee查询空行select* from titles where price is null使用常量列select stuNo as 学生学号, stuName as 学生姓名, '湖南软职业学院' as 所在学校from stuinfo限制固定行数use pubsselect TOP 5 * from titlesorder by price返回百分之多少行use pubsselect TOP 20 PERCENT * from titlesorder by price desc升序排列SELECT StudentID As 学员编号,(Score*0.9+5) As 综合成绩FROM Score WHERE (Score*0.9+5)>60ORDER BY Score asc降序排列use pubsSELECT Au_Lname +'.' +Au_fName AS EMPFrom Authors UnionSELECT fName +'.'+ LName AS EMPFrom EmployeeORDER BY EMP DESC按多列排序SELECT StudentID As 学员编号, Score As 成绩,courseID As 课程号FROM ScoreWHERE Score>60ORDER BY Score,courseID将stumark表中的内容插入到新表stumark1Select * into stumark1From stumark注:表stumark1不需要创建将stumarks表中的内容插入到表stumark1Insert into stumark1 Select * From stumark注:表stumark1需要先创建好插入一条记录到students 表,使得这条记录的SName, Scode 列值分别为‘anny', 5 inser t into students (SName, Scode) values('anny', 5);将students 表中代号为5的记录的姓名修改为左国才update students set SName = '左国才'where Scode = 5;删除姓名为左国才记录delete from students where SName='左国才';模糊查询--BETWEEN把某一字段中内容在特定范围内的记录查询出来SELECT StudentID, Score FROM SCore WHERE Score BETWEEN 60 AND 80把某一字段中内容与所列出的查询内容列表匹配的记录查询出来SELECT StuName AS 学员姓名,StuAddress As 地址FROM Stuinfo WHERE StuAddress IN ('北京','广州','上海')聚合函数--SUMUse pubsSELECT SUM(ytd_sales) FROM titles WHERE type = 'business'聚合函数--A VGUse 学生信息SELECT A VG(SCore) AS 平均成绩From Score WHERE Score >=60聚合函数--MAX / MINSELECT AVG(SCore) AS 平均成绩, MAX (Score) AS 最高分, MIN (Score) AS 最低分From Score WHERE Score >=60聚合函数--COUNTSELECT COUNT (*) AS 及格人数From ScoreWHERE Score>=60分组查询SELECT CourseID, A VG(Score) AS 课程平均成绩FROM ScoreGROUP BY CourseID.分组查询—HA VINGSELECT StudentID AS 学员编号,CourseID AS 内部测试, A VG(Score) AS 内部测试平均成绩FROM ScoreGROUP BY StudentID,CourseIDHA VING COUNT(Score)>1多表链接SELECT a.stuNo,a.stuName,b.stuNo,b.writtenExamFROM Stuinfo a,stumark bWHERE a.stuNo = b.stuNo注:a,b 分别为表Stuinfo,stumark 的别名SELECT Students.SName, Score.CourseID, Score.ScoreFROM Students,ScoreWHERE Students.SCode = Score.StudentID多表链接--内连接SELECT Students.SName, Score.CourseID, Score.ScoreFROM Students,ScoreWHERE Students.SCode = Score.StudentID多表链接--三表连接SELECTS.SName AS 姓名, CS.CourseName AS 课程, C.Score AS 成绩FROM Students AS SINNER JOIN Score AS C ON (S.SCode = C.StudentID)INNER JOIN Course AS CS ON (CS.CourseID = C.CourseID)多表链接--左外连接SELECT S.SName,C.CourseID,C.ScoreFrom Students AS SLEFT JOIN Score AS CON C.StudentID = S.SCode多表链接--右外连接SELECT Titles.Title_id, Titles.Title, Publishers.Pub_nameFROM titlesRIGHT OUTER JOIN PublishersON Titles.Pub_id = Publishers.Pub_id子查询SELECT * FROM stuInfoWHERE stuAge>( SELECT stuAge FROMstuInfo where stuName='李斯文')GO使用子查询替换表连接3-2 SELECT stuName FROM stuInfoINNER JOIN stuMarksON stuInfo.stuNo=stuMarks.stuNoWHERE writtenExam=60GOSELECT stuName FROM stuInfoWHERE stuNo=(SELECT stuNo FROMstuMarks WHERE writtenExam=60)GOIn子查询SELECT stuName FROM stuInfoWHERE stuNo IN(SELECT stuNo FROM stuMarksWHERE writtenExam=60)GO数据库的存在检测IF EXISTS(SELECT * FROMsysDatabases WHERE name=’stuDB’)DROP DATABASE stuDBCREATE DATABASE stuDB…….—建库代码略。
SQL Server 2005基础应用(入门到精通·循序渐进·案例详解·适合初学者)
SQL Server 2005基础应用一.数据库的基本操作--创建数据库create database new_db2on primary(name='new.mdf',filename='e:\new.mdf',size=5mb,maxsize=50mb,filegrowth=10%)--收缩数据库alter database new_dbmodify file(name='new_db',size=15mb)--压缩数据库dbcc shrinkdatabase('new_db',1)--重命名数据库exec sp_renamedb'new_db','Jasxu_db'--删除数据库drop database new_db2二.数据库表的基本操作--创建数据库create database st_dbon primary(name='st.mdf',filename='e:\st,mdf',size=5mb,maxsize=50mb,filegrowth=20%)--删除Jasxu_db数据库drop database Jasxu_db--在st_db数据库中编辑use st_db--创建表create table table_name(学号int primary key identity,--这里的identity意思就是将标志规范设置为递增名称char(6)not null,专业方向varchar(10)not null,系部代码char(2)not null,备注varchar(50))--查看表的基本信息exec sp_help table_name--重命名表exec sp_rename'table_name','new_table'--重命名列exec sp_rename'new_table.备注','其他','column'--添加新列alter table new_table add新列char(10)--更改列的数据类型alter table new_tablealter column新列int not null--删除列alter table new_tabledrop column新列--删除表drop table new_table--案例解析create table t2(id int not null,us varchar(30))--查询表里面的内容select*from t1--删除表的所有数据truncate table t1--创建主键约束alter table t1add constraint pkprimary key clustered(id)--创建外键约束alter table t2add constraint wzforeign key(id)references t1(id)--references代表参照哪个表的主键设置外键三.数据库表的增加、删除、修改--创建系部表create table系部(系部代码char(6)not null primary key,系部名称varchar(30)not null,系主任char(8))--创建专业表create table专业表(专业代码char(4)not null primary key,专业名称varchar(20)not null,系部代码char(6)constraint wz11 references系部(系部代码))--创建班级表create table班级表(班级代码char(9)not null primary key,班级名称varchar(20),专业代码char(4)constraint wz1 references专业表(专业代码),系部代码char(6)constraint wz2 references系部(系部代码),备注varchar(50))--创建学生表create table学生表(学号char(12)not null primary key,姓名char(8),性别char(2),出生日期datetime,入学时间datetime,班级代码char(9)constraint wz3 references班级表(班级代码),系部代码char(6)constraint wz4 references系部(系部代码),专业代码char(4)constraint wz5 references专业表(专业代码))--在new_table表中添加数据insert into new_table values('Jasxu','计算机','01','无')--选择性的插入数据insert into new_table(名称,专业方向,系部代码)values('xsw','软件工程','02') --省略values的insert语句insert into new_table (名称,专业方向,系部代码)select名称,专业方向,系部代码from new_table--修改new_table表update new_table set系部代码='01'update new_table set专业方向='软件工程'where专业方向='计算机'--删除new_table中的内容delete new_table where专业方向='软件工程'delete new_table where学号='10'四.数据库表的简单查询--查询new_table表中所有信息内容select*from new_tableselect学号,名称,专业方向,系部代码,其他from new_table--输出表中的部分字段select学号,名称from new_table--选择表中若干记录(去掉结果中的重复行)select distinct系部代码from new_table--限制返回的行数select top 3 *from new_table--查询学号大于的信息select*from new_table where学号>13--确定范围(between and)select*from new_table where学号between 12 and 16--确定集合(in,not in)select*from new_table where学号in(12,13,14,15)select*from new_table where学号not in(12,13,14,15)--字符匹配select*from new_table where名称like'徐_'--两个字的姓名select*from new_table where名称like'徐__'--三个字的姓名select*from new_table where名称like'徐%'--%代表任意长度select*from new_table where名称like'徐\%'escape'\'--通配符的转换--清空数据truncate table new_table--插入数据insert into new_table values('张学友','网络','01','没有','411')insert into new_table values('刘德华','计算机','02','没有','412') insert into new_table values('舒淇','计算机','01','没有','413')insert into new_table values('梁咏琪','动漫','02','没有','431')insert into new_table values('杨千嬅','计算机','01','没有','465') insert into new_table values('李宇春','动漫','02','没有','485')insert into new_table values('蔡依林','网络','01','没有','468')insert into new_table values('郑源','计算机','02','没有','510')insert into new_table values('陈楚生','动漫','01','没有','550')insert into new_table values('张韶涵','计算机','02','没有','421') insert into new_table values('猛非','动漫','01','没有','423')insert into new_table values('郑秀文','网络','02','没有','411')insert into new_table values('林俊杰','计算机','01','没有','511') insert into new_table values('羽泉','计算机','01','没有','500')insert into new_table values('郭富城','网络','02','没有','400')insert into new_table values('黄品源','动漫','02','没有','589')insert into new_table values('梁朝伟','计算机','02','没有','530') insert into new_table values('李克勤','网络','01','没有','520')insert into new_table values('陈小春','国际金融','02','没有','512') insert into new_table values('刘若英','证券期货','02','没有','421') insert into new_table values('刘嘉玲','房地产金融','01','没有','428') insert into new_table values('谭咏麟','房地产金融','02','没有','498') insert into new_table values('张学友','证券期货','01','没有','454') insert into new_table values('张卫健','证券期货','02','没有','515') insert into new_table values('周传雄','房地产金融','01','没有','532') insert into new_table values('周星驰','国际金融','02','没有','423') insert into new_table values('游鸿明','房地产金融','02','没有','447') insert into new_table values('言承旭','国际金融','02','没有','488') insert into new_table values('许志安','国际金融','01','没有','582') insert into new_table values('叶倩文','房地产金融','01','没有','495') insert into new_table values('叶世荣','房地产金融','02','没有','499') insert into new_table values('张雨生','证券期货','02','没有','531') insert into new_table values('周润发','国际金融','01','没有','531') insert into new_table values('张信哲','证券期货','01','没有','424') insert into new_table values('周渝民','证券期货','02','没有','412') insert into new_table values('太极乐队','证券期货','02','没有','423') --查询new_table表select*from new_table--涉及空值的查询select*from new_table where其他is nullselect*from new_table where not其他is null--用指定使用结果值来创建一个表(注意:在表前加一个#创建出来的是临时表)select学号,名称,高考分数into score_table from new_tableselect*from score_table--对结果进行分组select系部代码from new_table group by系部代码select专业方向from new_table group by专业方向select专业方向from new_table group by专业方向having专业方向<>'动漫'--having起到筛选作用--排序查询(asc升序desc降序)select*from new_table order by高考分数ascselect*from new_table order by高考分数desc五.数据表中对数据进行统计--查询数据库表new_table中的信息select*from new_tableselect*from new_table order by高考分数descselect top 3 *from new_table order by高考分数desc--查询总人数select count(*)as总人数from new_table--这里的as是为列重命名select count(学号)as总人数from new_tableselect count(其他)as总人数from new_table--计算整个班级高考的总分数select sum(高考分数)as总分from new_table--计算整个班级高考的平均分数select avg(高考分数)as平均分from new_table--计算整个班级高考的最大值select max(高考分数)as最大值from new_table--计算整个班级高考的最小值select min(高考分数)as最小值from new_table--对查询结果集中的所有记录进行汇总统计,并显示所有参加汇总记录的详细信息select*from new_table order by专业方向compute sum(高考分数)select专业方向,count(*)as总人数from new_table group by专业方向--统计专业方向一共多少select专业方向,count(*)as总人数from new_table group by专业方向compute count(专业方向)--统计系部总人数select专业方向,count(*)as总人数from new_table group by专业方向compute sum(count(*))六.数据库中表的连接查询--插入数据这里的go起到连接作用insert into系部(系部代码,系部名称,系主任)values('01','计算机系','老张') goinsert into系部(系部代码,系部名称,系主任)values('02','经济管理系','老陈') goinsert into系部(系部代码,系部名称,系主任)values('03','机械系','老李')goinsert into系部(系部代码,系部名称,系主任)values('04','计算机系','老梁') goinsert into专业表(专业代码,专业名称,系部代码)values('0101','软件工程','01')goinsert into专业表(专业代码,专业名称,系部代码)values('0102','网络工程','01')goinsert into专业表(专业代码,专业名称,系部代码)values('0103','信息工程','01')goinsert into专业表(专业代码,专业名称,系部代码)values('0201','工商管理','02')goinsert into专业表(专业代码,专业名称,系部代码)values('0202','物流管理','02')goinsert into专业表(专业代码,专业名称,系部代码)values('0301','模具加工','03')goinsert into专业表(专业代码,专业名称,系部代码)values('0302','机电一体化','03')goinsert into专业表(专业代码,专业名称,系部代码)values('0401','应用数学','04')goinsert into专业表(专业代码,专业名称,系部代码)values('0402','金融数学','04')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010101','软件工程班','0101','01','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010102','软件工程班','0101','01','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010103','网络工程班','0102','01','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010104','网络工程班','0102','01','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010105','信息工程班','0103','01','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010106','工商管理班','0201','02','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010107','物流管理班','0202','02','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010108','模具加工班','0301','03','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注)values('010109','应用数学班','0401','04','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注) values('0101010','金融数学班','0402','04','暂无')goinsert into班级表(班级代码,班级名称,专业代码,系部代码,备注) values('0101011','金融数学班','0402','04','暂无')goinsert into学生表values('010*********','刘德华','男','1988-5-5','2010-9-1','010101','01','0101')goinsert into学生表values('010*********','张学友','男','1988-1-4','2010-9-1','010102','02','0102')goinsert into学生表values('010*********','梁静茹','女','1988-2-1','2010-9-1','010103','03','0103')goinsert into学生表values('010*********','陈奕迅','男','1983-5-3','2010-9-1','010104','04','0201')goinsert into学生表values('010*********','张韶涵','女','1987-8-6','2010-9-1','010105','01','0202')goinsert into学生表values('010*********','林俊杰','男','1988-6-6','2010-9-1','010106','02','0301')goinsert into学生表values('010*********','孙燕姿','女','1984-5-3','2010-9-1','010107','03','0302')goinsert into学生表values('010*********','周华健','男','1986-8-6','2010-9-1','010108','04','0401')goinsert into学生表values('010*********','尚雯婕','女','1988-6-6','2010-9-1','010109','01','0402')goinsert into学生表values('010*********','任贤齐','男','1984-5-3','2010-9-1','0101010','02','0101')goinsert into学生表values('010*********','魏晨','男','1986-8-6','2010-9-1','0101011','03','0102')goinsert into学生表values('010*********','庞龙','男','1988-6-6','2010-9-1','010101','04','0103')goinsert into学生表values('010*********','刘若英','女','1988-5-3','2010-9-1','010102','01','0201')goinsert into学生表values('010*********','李圣杰','男','1989-8-6','2010-9-1','010103','02','0202')goinsert into学生表values('010*********','吴克群','男','1989-2-9','2010-9-1','010104','03','0301')go--连接查询(交叉查询)select*from学生表cross join班级表--列举学生表中的学生姓名和性别班级表中的班级名称select学生表.姓名,学生表.性别,班级表.班级名称from学生表cross join班级表--将两个表中相同列合为一列select学生表.姓名,学生表.性别,班级表.班级名称from学生表cross join班级表where学生表.班级代码=班级表.班级代码--自然连接select*from学生表join班级表on学生表.班级代码=班级表.班级代码select学生表.姓名,学生表.性别,班级表.班级名称from学生表join班级表on学生表.班级代码=班级表.班级代码--表的自身连接(需要取别名)select a.姓名,b.性别from学生表as a join学生表as b on a.学号=b.学号--外连接表查询create table产品(产品编号char(9)not null,产品名称varchar(20)not null)create table产品销售(产品编号char(9)not null,销量int)insert into产品values('001','显示器')insert into产品values('002','键盘')insert into产品values('003','鼠标')insert into产品销售values('001','25')insert into产品销售values('003','35')insert into产品销售values('005','30')select*from产品select*from产品销售--左外连接select*from产品left join产品销售on产品.产品编号=产品销售.产品编号--右外连接select*from产品right join产品销售on产品.产品编号=产品销售.产品编号--完全外连接select*from产品full join产品销售on产品.产品编号=产品销售.产品编号--合并结果集(把重复的过滤掉了)select姓名,性别,出生日期from学生表union select姓名,性别,出生日期from学生表七.数据库中多表查询和子查询--多表连接查询select学生表.学号,学生表.姓名,学生表.性别,班级表.班级名称,专业表.专业名称,系部.系部名称from学生表join班级表on学生表.班级代码=班级表.班级代码join专业表on学生表.专业代码=专业表.专业代码join系部on学生表.系部代码=系部.系部代码select学生表.学号,学生表.姓名,学生表.性别,班级表.班级名称from学生表join班级表on学生表.班级代码=班级表.班级代码and性别='男'--嵌套查询(子查询)带有IN运算符的子查询,in运算符的子查询返回的结果是集合select*from系部select*from学生表where系部代码='01'select*from学生表where班级代码in(select班级代码from班级表where专业代码in(select专业代码from专业表where系部代码in(select系部代码from系部where系部代码in(01))))--带有比较运算符的子查询select*from学生表where出生日期>(select出生日期from学生表where姓名='刘德华')--带有any(满足条件中的任何一个)或all(大于结果中的所有值)的子查询select*from score_table order by高考分数descselect*from score_table where高考分数>any(select高考分数fromscore_table where学号in(29,25))select*from score_table where高考分数>all(select高考分数fromscore_table where学号in(29,25))--带有exists运算符的子查询select*from score_table where exists(select*from score_table where 名称='张学友')八.数据库中数据完整性约束select*from系部where系部代码=(select系部代码from专业表where专业代码=(select专业代码from班级表where班级代码=(select班级代码from学生表where姓名='刘德华')))--使用sql语句创建唯一约束alter table系部add constraint wywy unique nonclustered(系部名称)--创建检查约束alter table score_table add constraint ck_name check(高考分数>300 and高考分数<600)--创建默认约束alter table new_table add constraint df default'我叫徐守威'for'其他' --删除约束alter table score_table drop constraint ck_name九.数据库中数据规则--创建规则create rule gz as @a>300 and @a<600--绑定规则execute sp_bindrule'gz','new_table.高考分数'select*into new_table1 from new_table--解除规则execute sp_unbindrule'new_table.高考分数'--删除规则drop rule gz--创建默认create default df_name as'男'--绑定默认execute sp_bindefault'df_name','学生表.性别'--解除默认execute sp_unbindefault'df_name','学生表.性别'--删除默认drop default df_name十.数据库中索引--创建索引create clustered index索引名on score_table(名称)create unique clustered index索引名on score_table(名称)--查看索引信息execute sp_helpindex score_table--删除索引drop index score_table.索引名十一.数据库视图--创建视图create view v1 asselect学生表.学号,学生表.姓名,班级表.班级名称,专业表.专业名称,系部.系部名称from学生表join班级表on学生表.班级代码=班级表.班级代码join专业表on班级表.专业代码=专业表.专业代码join系部on专业.系部代码=系部.系部代码--创建一般视图create view视图名asselect*from score_table--创建加密视图create view加密视图名with encryptionasselect*from score_table--创建视图及表的架构绑定create view视图及表的架构绑定with schemabindingasselect姓名,性别from dbo.score_table--在视图中增加、删除数据insert into视图名(姓名,性别)values('xushouwei','男')update视图名set姓名='徐守威'where姓名='xushouwei'delete视图名where姓名='徐守威'--删除视图drop view视图名--系统存储过程查看视图execute sp_helptext视图名十二.数据库存储过程--创建存储过程create procedure passelect学生表.学号,学生表.姓名,班级表.班级名称,专业表.专业名称,系部.系部名称from学生表join班级表on学生表.班级代码=班级表.班级代码join专业表on班级表.专业代码=专业表.专业代码join系部on专业表.系部代码=系部.系部代码--执行存储过程execute p--为存储过程加上参数create procedure p1@sex varchar(10),@id varchar(10)asselect学生表.学号,学生表.姓名,班级表.班级名称,专业表.专业名称,系部.系部名称from学生表join班级表on学生表.班级代码=班级表.班级代码and学生表.性别=@sexjoin专业表on班级表.专业代码=专业表.专业代码join系部on专业表.系部代码=系部.系部代码and系部.系部代码=@id--执行带参数的存储过程execute p1'男','01'--创建带返回参数的存储过程create procedure p2@name varchar(10),@getnum varchar(10)outputasselect @getnum=学号from学生表where姓名=@name--执行带返回参数的存储过程execute p2'刘德华',''--查看存储过程execute sp_helptextexecute sp_dependsexecute sp_help--删除存储过程drop procedure pdrop procedure p,p1drop procedure p,p1,p2十三.数据库触发器--创建触发器(执行插入操作)create trigger myinserton产品for insertasdeclare @a char(10)select @a=产品编号from insertedinsert into产品销售values(@a,0)--查询触发器中的数据select*from产品select*from产品销售--执行插入操作insert into产品values('01','电视')insert into产品values('02','电脑')--创建触发器(执行删除操作)create trigger mydeleteon产品for deleteasdeclare @a char(10)select @a=产品编号from deleteddelete产品销售where产品编号=@a--执行删除操作delete产品where产品编号='02'--查看触发器信息execute sp_helptrigger产品--删除触发器drop trigger myinsertdrop trigger mydelete十四.数据库函数--avg求平均分函数select班级名称,avg(学生表.高考分数)from班级表join学生表on班级表.班级代码=学生表.班级代码group by班级名称--max求最大值select班级名称,max(学生表.高考分数)from班级表join学生表on班级表.班级代码=学生表.班级代码group by班级名称--min求最小值select班级名称,min(学生表.高考分数)from班级表join学生表on班级表.班级代码=学生表.班级代码group by班级名称--abs(x)返回绝对值select abs(-8)--ceiling(x)返回大于或等于所给数字的最小整数select ceiling(3)--pi()(pi值)select pi()--power(x,y)返回x的y次方select power(2,3)--rand()返回~1之间的随机数select rand()--返回数据库的版本号select@@version--获取当前语言select@@language--当前时间select getdate()--取出天select day(getdate())--取出月select month(getdate())--取出年select year(getdate())--加三天(“d”表示天,“m”表示月,“y”表示年)select dateadd(d,3,getdate())as Jasxu_dateadd--取出时间的某一部分(“d”表示天,“m”表示月,“y”表示年)select datename(d,'2013-12-12')select datename(d,getdate())--排名函数select姓名,rank()over(order by高考分数desc)as名次,高考分数from学生表。
sqlserver2005 concat函数 -回复
sqlserver2005 concat函数-回复SQL Server 2005是微软发布的一款关系型数据库管理系统,具有强大的数据处理和查询功能,其中的concat函数在字符串处理方面非常重要。
这篇文章将逐步回答关于concat函数的问题,并从基本用法到高级应用深入探讨,帮助读者充分理解和应用该函数。
1. 什么是concat函数?concat函数是SQL Server 2005中提供的一个字符串处理函数,用于将多个字符串连接在一起形成一个新的字符串。
通过concat函数,我们可以方便地将多个字段或常量值组合成一个字符串。
2. concat函数的基本语法是什么?concat函数的基本语法如下:concat(string1, string2, ..., stringN)其中,string1到stringN是要连接的字符串,可以是字段、常量值或表达式。
3. 如何使用concat函数进行字符串连接?使用concat函数进行字符串连接非常简单,只需要将要连接的字符串按照需要的顺序依次列出即可。
例如,要将"Hello"和"World"连接成一个字符串,可以使用如下语句:SELECT concat('Hello', 'World') AS ConcatenatedString;4. 如何在concat函数中使用字段?除了常量值和表达式之外,我们还可以在concat函数中使用数据库表中的字段。
例如,假设有一个名为"FirstName"的字段和一个名为"LastName"的字段,我们可以使用如下语句将它们连接为一个完整的名字:SELECT concat(FirstName, ' ', LastName) AS FullName FROM Employees;5. concat函数对于空值的处理方式是什么?当concat函数中的任何一个参数为NULL时,函数将返回NULL。
SQL Server 2005_函数整理
重要知识点:1.模糊查询关键字:like的用法。
Like 后面主要有4种通配符,需要知道具体的通配符所表示的意义。
具体如下:(1)%:匹配包含0个或多个的字符串(2)_ :匹配任何单个字符(3)[] :匹配任何在范围或集合之内的单个字符,如:[1-3]只匹配1、2、3(4)[^]:匹配任何不在范围内或集合内的单个字符,如[^1-3]匹配除1、2、3之外的其他字符2.取模计算(%)。
在数学计算是可能会用到。
主要是取两个数相除的余数。
(需要了解一下)如:select 89/16,89%16 前一个结果是5 后一个是9。
函数整理注意,如果需要更多的例子,可以在SQL自带的联机帮助文档中查找,里面的内容很丰富。
基本上所有的函数都有相关的例子进行解释。
一、重要的函数,需要掌握(共列取21个函数)1、聚合函数聚合函数对一组值执行计算,并返回单个值。
除了COUNT 以外,聚合函数都会忽略空值。
聚合函数经常与SELECT 语句的GROUP BY 子句一起使用。
聚合函数的常用使用格式:函数名([all|distinct] 表达式)all:默认值,对所有的值进行聚合函数运算包含重复值。
distinct: 消除重复值后进行聚合函数运算。
2、字符串函数3、日期和时间函数(指定要返回新值的日期的组成部分。
下表列出了Microsoft SQL Server 2005 可识别的日期部分及其缩写。
)红色是一定要知道的,在写日期部分的时候如果是不清楚缩写那可以写全称的4、数学函数:5、数据类型转换函数日期类型数据转换为字符数据类型的日期格式的部分样式表。
下面列取的是几个比较常用的日期格式,其中108,112和120这三种用的比较多需要掌握。
下面是convert 函数用到的部分样式。
6、isnull()重要,需要理解二、需要了解的一些函数。
排名函数排名函数的常用使用格式:函数名() over (order by 列名 [asc|desc][,列名……]) 其中row_number需要了解,其他两个只需要知道就可以字符串函数日期和时间函数数学函数三、只要知道有相应的函数,到使用时可以查找相关的资料的函数,可以稍作了解字符串函数日期和时间函数数学函数当两个不同数据类型的表达式用运算符组合后,数据类型优先级规则指定将优先级较低的数据类型优先转换为优先级较高的数据类型。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
表达式:是常量、变量、列或函数等与运算符的任意组合。
以下参数中表达式类型是指表达式经运算后返回的值的类型字符串函数
日期和时间函数
可识别的日期部分及其缩写。
)
数学函数
数据类型转换函数
日期类型数据转换为字符数据类型的日期格式的部分样式表
当两个不同数据类型的表达式用运算符组合后,数据类型优先级规则指定将优先级较低的数据类型优先转换为优先级较高的数据类型。
如果此转换不是所支持的隐式转换,则返回错误。
当两个操作数表达式具有相同的数据类型时,运算的结果便为该数据类型。
如果需要把优先级高的数据类型转换为优先级低的数据类型时需要使用数据类型转换函数进行显示转换。
SQL Server 2005 对数据类型使用以下优先级顺序(先高后低):
1、用户定义数据类型(最高)
2、sql_variant
3、xml
4、datetime
5、smalldatetime
6、float
7、real
8、decimal
9、money10、smallmoney
11、bigint12、int13、smallint14、tinyint15、bit16、ntext17、text18、image19、timestamp20、uniqueidentifier
21、nvarchar(包括nvarchar(max))22、nchar23、varchar (包括varchar(max))24、char25、varbinary(包括varbinary(max))
26、binary(最低)
下图提供了SQL Server2005中数据类型转换的说明
排名函数
排名函数的常用使用格式:函数名() over (order by 列名 [asc|desc][,列名……])
注意:返回结果集会根据使用排名函数时指定的列进行排序,因此不要在from子句后面再次使用order by,会导致排名混乱。
聚合函数对一组值执行计算,并返回单个值。
除了COUNT 以外,聚合函数都会忽略空值。
聚合函数经常与SELECT 语句的GROUP BY 子句一起使用。
聚合函数的常用使用格式:函数名([all|distinct] 表达式)
all:默认值,对所有的值进行聚合函数运算包含重复值。
distinct: 消除重复值后进行聚合函数运算。