-
sql普通行列转换
问题:假设有张学生成绩表(tb)如下:姓名课程分数张三语文74张三数学83张三物理93李四语文74李四数学84李四物理94想变成(得到如下结果):姓名语文数学物理----------------李四748494张三748393-------------------*/createtabletb(姓名varchar(10),课程varchar(10),分数int)insertintotbvalues('张三','语文',74)insertintotbvalues('张三','数学',83)insertintotbvalues('张三','物理',93)insertintotbvalues('李四','语文',74)insertintotbvalues('李四','数学',84)insertintotbvalues('李四','物理',94)go--SQLSERVER2000静态SQL,指课程只有语文、数学、物理这三门课程。(以下同)select姓名as姓名,max(case课程when'语文'then分数else0end)语文,max(case课程when'数学'then分数else0e...
数据库操作教程 2022-09-23 20:30:30 -
SQL语句实现删除ACCESS重复记录的两种方法
以下就重复记录删除的问题作一阐述。有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略...
数据库操作教程 2022-09-23 20:23:15 -
将MSSQLSERVER数据库运行在普通用户(独立用户)状态下的设置方法终结篇
看了脚本之家网上的很多文章,整理了如下步骤,基本上可以说是终结解决方法了,这里给详细的整理下了,希望可以帮助更新的朋友,让我们的服务器更加安全。脚本之家奉献...
数据库操作教程 2022-09-23 20:13:07 -
SQL年龄计算的两种方法实例
目录第一种方法:第二种方法:总结第一种方法:用DATEDIFF函数,DATEDIFF(YEAR,beginDate,endDate)。测试语句:DECLARE@birthdayDateDATEDECLARE@endDateDATEDECLARE@ageINTSET@birthdayDate='2003-08-08'SET@endDate='2008-07-08'SET@age=DATEDIFF(YEAR,@birthdayDate,@endDate)SELECT@ageAS年龄执行结果:这种方法计算出的年龄,是个大概年龄,是“年”意义下的年龄,就是普罗大众对年龄的理解下的年龄...
数据库操作教程 2022-09-23 18:19:35 -
SqlServer如何查看被锁的表及解锁的方法
查看被锁表:selectspIdfrommaster..SysProcesseswheredb_Name(dbID)='数据库名称'andspId<>@@SpIdanddbID<>0解除锁:exec('Kill'+cast(@spidasvarchar))查看被锁表:selectrequest_session_idspid,OBJECT_NAME(resource_associated_entity_id)tableNamefromsys.dm_tran_lockswhereresource_type='OBJECT'spid锁表进程tableName被锁表名解锁:declare@spidintSet@spid=57--锁表进程declare@sqlvarchar(1000)set@sql='kill'+cast(@spidasvarchar)exec(@sql)以上所述是小编给大家介绍的SqlServer如何查看被锁的表及解锁的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!...
数据库操作教程 2022-09-23 18:03:03 -
修改数据库为多用户模式
修改数据库为多用户模式SQL语句修改数据位多用户模式如下:DECLARE@SQLVARCHAR(MAX);SET@SQL=''SELECT@SQL=@SQL+';KILL'+RTRIM(SPID)FROMmaster....
数据库操作教程 2022-09-23 17:57:07 -
配置SQLServer数据库恢复模式(2种方法)
下面主要介绍配置SQLServer数据库恢复模式的两种方法。用T-SQL设置恢复模式你可以使用“ALTERDATABASE”命令加“SETRECOVERY”语句来修改数据库的恢复模式...
数据库操作教程 2022-09-23 17:47:00 -
SQLServer两种分页的存储过程使用介绍
由于现在很多的企业招聘的笔试都会让来招聘的写一个分页的存储过程,有的企业甚至要求应聘者用两种方式实现分页,如果没有在实际项目中使用过分页,那么很多的应聘者都会出现一定的问题,下面介绍两种分页的方法。一、以学生表为例,在数据库中有一个Student表,字段有StudentNo,,LoginPwd,StudentName,Sex,ClassId,Phone,Address,BornDate,Email,isDel要求:查询学生的信息,每页显示5条记录二、第一种方式分页:利用子查询notin例如:第一页selecttop5*fromStudent第二页:查询前10条中不在前5条的记录,那么就是6-10,也就是第二页selecttop5*fromStudentwhereStudentNonotin(selecttop10StudentnofromStudent)同理可以得到第三页、、、、、、、这种方式相信大家都能明白,这种分页的存储过程写法就不多做介绍,重点介绍下面那种分页方法...
数据库操作教程 2022-09-23 17:46:34 -
sqlserver锁表、解锁、查看销表的方法
锁定数据库的一个表复制代码代码如下:SELECT*FROMtableWITH(HOLDLOCK)注意:锁定数据库的一个表的区别复制代码代码如下:SELECT*FROMtableWITH(HOLDLOCK)其他事务可以读取表,但不能更新删除复制代码代码如下:SELECT*FROMtableWITH(TABLOCKX)其他事务不能读取表,更新和删除SELECT语句中“加锁选项”的功能说明SQLServer提供了强大而完备的锁机制来帮助实现数据库系统的并发性和高性能。用户既能使用SQLServer的缺省设置也可以在select语句中使用“加锁选项”来实现预期的效果...
数据库操作教程 2022-09-23 17:45:23 -
MySql查询不区分大小写解决方案(两种)
当我们输入不管大小写都能查询到数据,例如:输入aaa或者aaA,AAA都能查询同样的结果,说明查询条件对大小写不敏感。解决方案一:于是怀疑Mysql的问题...
数据库操作教程 2022-09-23 17:44:44 -
sqlserver创建临时表的两种写法和删除临时表
--创建、删除临时表--第一种方式createtable#tmp(namevarchar(255),idint)--第二种方式selectcount(id)asstoryNum,sum(convert(numeric(10,2),casewhenisnumeric(code)=1thencodeelse0end))ascodeNum,sum((casewhenisnumeric(realcode)=1thenconvert(numeric(10,2),realcode)else0.0end))asrealcodeNum,tdtname,cycle,jiracomponent,jirastatename,qualityvalue,storycodelltinto#tmpfromIKNOW_STORY_U2000V1R7C00groupbytdtname,cycle,jiracomponent,jirastatename,qualityvalue,storycodellt--查询临时表select*from#tmp--删除临时表ifobject_id('tempdb..#tmp')isno...
数据库操作教程 2022-09-23 17:41:35