-
SQLServer创建数据库和数据表的相关约束实现方法
本文分析了SQLServer创建数据库和数据表的相关约束实现方法。分享给大家供大家参考,具体如下:创建约束语法如下:CREATEDATABASE[test]ON(NAME=N'test',FILENAME=N'd:SQL2kt_Datatest.mdf',SIZE=3mb,MAXSIZE=UNLIMITED,FILEGROWTH=1MB)LOGON(NAME=N'test_log',FILENAME=N'd:SQL2kt_Datatest_log.ldf',SIZE=1MB,MAXSIZE=2048MB,FILEGROWTH=10%)GO名词解释(翻译):constraint1.约束;限制[C][(+on)]legalconstraintsonthecompany'sactivities对该公司活动法律的限制2.强迫;强制[U]Heactedunderconstraint.他被迫采取行动...
数据库操作教程 2022-09-23 17:45:07 -
某年第一周开始日期实现方法
参考网址https://www.jb51.net/article/29551.htm复制代码代码如下:SELECT[StartDate]FROM[dbo].[udf_Week](2012,2012)WHERE[Week]=1上面SQL语句执行结果:但你还是觉得此方法很复杂,而且只需要日期部分,时间部分无需显示。因此Insus.NET更改并产生如下一个新函数,你把函数附加入你的数据库中,即可在程序中应用它了...
数据库操作教程 2022-09-23 17:43:36 -
实现SQL分页的存储过程代码
SQL分页的存储过程代码,需要的朋友们直接拿去用,使用非常简单。分享代码如下USE[SendMessage]GO/******Object:StoredProcedure[dbo].[pages]ScriptDate:07/09/201513:46:50******/SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOALTERPROC[dbo].[pages](@tbnamenvarchar(100),--要分页显示的表名@FieldKeynvarchar(1000),--用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段@PageCurrentint=1,--要显示的页码@PageSizeint=10,--每页的大小(记录数)@FieldShownvarchar(1000)='',--以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段@FieldOrdernvarchar(1000)='',--以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC@WhereStringnvarchar(1000)=N''--查询条件)ASbe...
数据库操作教程 2022-09-23 17:40:24 -
SQL语句实现查询当前数据库IO等待状况
sys.dm_io_pending_io_requests可以返回当前IOPending的状态,对于SQLServer中每个挂起的I/O请求,返回与其对应的一行,跟sys.dm_io_virtual_file_stats配合可以看到具体是哪个数据库IO出现问题。selectDB_NAME(database_id)asDBNAME,database_id,file_id,io_stall,io_pending_ms_ticks,scheduler_addressfromsys.dm_io_virtual_file_stats(null,null)i,sys.dm_io_pending_io_requestsswheres.io_handle=i.file_handle...
数据库操作教程 2022-09-23 17:40:11 -
SQLServer将一列的多行内容拼接成一行的实现方法
下面大家先看下示例代码:示例昨天遇到一个SQLServer的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行,比如表中有两列数据:类别名称AAA企业1AAA企业2AAA企业3BBB企业4BBB企业5我想把这个表变成如下格式:类别名称AAA企业1,企业2,企业3BBB企业4,企业5一开始挺头疼的(会了的肯定没有这种感觉,不会那必须是头疼啊(*^__^*)),从网上找了点资料,算是找到一种比较简单方便的方法吧,现在大体总结一下,供大家共同学习。原先的表名为Table_A,实现代码如下:select类别,名称=(stuff((select','+名称fromTable_Awhere类别=A.类别forxmlpath('')),1,1,''))fromTable_AasAgroupby类别这里使用了SQLServer2005版本以后加入的stuff以及forxmlpath,先说下在上面这句sql中的作用,然后再详细的说明一下这两个的用法...
数据库操作教程 2022-09-23 17:38:45 -
SQL语句实现查询SQLServer服务器名称和IP地址
获取服务器名称:SELECTSERVERPROPERTY('MachineName')select@@SERVERNAMEselectHOST_NAME()获取IP地址可以使用xp_cmdshell执行ipconfig命令:--开启xp_cmdshellexecsp_configure'showadvancedoptions',1reconfigurewithoverrideexecsp_configure'xp_cmdshell',1reconfigurewithoverrideexecsp_configure'showadvancedoptions',0reconfigurewithoverridegobegindeclare@iplinevarchar(200)declare@posintdeclare@ipvarchar(40)setnocountonset@ip=nullifobject_id('tempdb....
数据库操作教程 2022-09-23 17:38:36 -
SQL语句实现查询SQLServer内存使用状况
SELECTtype,--Clerk的类型sum(virtual_memory_reserved_kb)asvm_Reserved_kb,--保留的内存sum(virtual_memory_committed_kb)asvm_Committed_kb,--提交的内存sum(awe_allocated_kb)asawe_Allocated_kb,--开启AWE后使用的内存sum(shared_memory_reserved_kb)assm_Reserved_kb,--共享的保留内存sum(shared_memory_committed_kb)assm_Committed_kb,--共享的提交内存sum(single_pages_kb)asSinlgePage_kb,--BufferPool中的Stolen的内存sum(multi_pages_kb)asMultiPage_kb--MemToLeave的内存FROMsys.dm_os_memory_clerksGROUPBYtypeORDERBYtype--查询BufferPool/MemoryToLeaveSELECTsum(virtua...
数据库操作教程 2022-09-23 17:37:58 -
SqlServer实现类似Oracle的before触发器示例
1.插入数据前判断数据是否存在SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGO--=============================================--Author:<Author,,Name>--Createdate:<CreateDate,,>--Description:<Description,,>--=============================================alterTRIGGERCategoryExistTriggerONProductCategoryinsteadofinsertASdeclare@categoryNamevarchar(50);BEGIN--SETNOCOUNTONaddedtopreventextraresultsetsfrom--interferingwithSELECTstatements...
数据库操作教程 2022-09-23 17:35:39 -
SQLServer中使用SQL语句实现把重复行数据合并为一行并用逗号分隔
一.定义表变量复制代码代码如下:DECLARE@T1table(UserIDint,UserNamenvarchar(50),CityNamenvarchar(50));insertinto@T1(UserID,UserName,CityName)values(1,'a','上海')insertinto@T1(UserID,UserName,CityName)values(2,'b','北京')insertinto@T1(UserID,UserName,CityName)values(3,'c','上海')insertinto@T1(UserID,UserName,CityName)values(4,'d','北京')insertinto@T1(UserID,UserName,CityName)values(5,'e','上海')select*from@T1-----最优的方式SELECTCityName,STUFF((SELECT','+UserNameFROM@T1subTitleWHERECityName=A.CityNameFORXMLPATH('')),1,1,'')ASAF...
数据库操作教程 2022-09-23 17:34:05