-
DATASET与DATAREADER对象有什么区别
DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection(俗称:非断开式连接),在线操作数据库时,任何对SqlConnection的操作都会引发DataReader的异常。因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的...
数据库操作教程 2022-09-23 18:01:15 -
SQLServer数据类型char、nchar、varchar、nvarchar的区别浅析
在SQLServer中,当我们设置字符型字段的时候,往往有很多个数据类型供我们选择,如:charncharvarcharnvarchar等,那么我们到底应该选择哪一个呢?下面就一一来描述其区别。char:固定长度,非Unicode字符数据,长度为n个字节...
数据库操作教程 2022-09-23 18:00:22 -
SqlServer修改数据库文件及日志文件存放位置
--查看当前的存放位置selectdatabase_id,name,physical_nameASCurrentLocation,state_desc,sizefromsys.master_fileswheredatabase_id=db_id(N'数据库名');--修改文件的存放位置下次启动生效--testDb为数据库名,alterdatabase数据库名modifyfile(name=文件名(不包含后缀),filename='文件存储路径');alterdatabase数据库名modifyfile(name=文件名(不包含后缀),filename='文件存储路径');eg...
数据库操作教程 2022-09-23 17:56:21 -
数据库触发器DB2和SqlServer有哪些区别
大部分数据库语句的基本语法是相同的,但具体到的每一种数据库,又有些不一样,例如触发器,DB2和SQLServer两种很大的不同。例如DB2的一个触发器:CREATETRIGGEREAS.trNameNOCASCADEBEFOREinsert//插入触发器ONeas.T_userREFERENCINGNEWASN_ROW//把新插入的数据命名为N_ROWFOREACHROWMODEDB2SQL//每一行插入数据都出发此操作BEGINATOMIC//开始DECLAREU_xtfidemp1varchar(36);//定义变量DECLAREu_xtempcode1varchar(20);DECLAREu_xtempcodeCountint;DECLAREU_xtfidempCountint;DECLAREu_id1int;setU_xtfidemp1=N_ROW.U_xtfidemp;//把新插入的数据赋值给变量setu_xtempcode1=N_ROW.u_xtempcode;setu_id1=N_ROW.u_id;setu_xtempcodeCount=(selectcount(u_xt...
数据库操作教程 2022-09-23 17:53:43 -
SQLServer表变量和临时表的区别(详细补充篇)
一、表变量 表变量在SQLServer2000中首次被引入。表变量的具体定义包括列定义,列名,数据类型和约束...
数据库操作教程 2022-09-23 17:50:58 -
没有SQLServer数据库时如何打开.MDF文件
如果您在试图打开一个.MDF数据库文件时,却发现自己没有安装SQLServer数据库,该怎么办呢?这时候,如果恰巧您的机子上装有VisualStudio2005或者是更高的版本时,不用安装SQLServer数据库也能打开.MDF数据库文件。本文我们主要介绍了这一方法的实现,接下来我们就开始介绍...
数据库操作教程 2022-09-23 17:44:31 -
实例理解SQL中truncate和delete的区别
本文以一个简单实例为大家介绍了SQL中truncate和delete的区别,帮助大家理解,具体内容如下---创建表Table1IFOBJECT_ID('Table1','U')ISNOTNULLDROPTABLETable1GOCREATETABLETable1(IDINTNOTNULL,FOIDINTNOTNULL)GO--插入测试数据INSERTINTOTable1VALUES(1,101),(2,102),(3,103),(4,104)GO---创建表Table2IFOBJECT_ID('Table2','U')ISNOTNULLDROPTABLETable2GOCREATETABLETable2(FOIDINTNOTNULL)GO--插入测试数据INSERTINTOTable2VALUES(101),(102),(103),(104)GOSELECT*FROMTable1GOSELECT*FROMTable2GO在Table1表中创建触发器,当表中的数据被删除时同时删除Table2表中对应的FOIDCREATETRIGGERTG_Table1ONTable1AFTERDELET...
数据库操作教程 2022-09-23 17:42:41 -
SQLServer无法收缩日志文件的原因分析及解决办法
最近服务器执行收缩日志文件大小的job老是报错我所用的一个批量收缩日志脚本USE[master]GO/******Object:StoredProcedure[dbo].[ShrinkUser_DATABASESLogFile]ScriptDate:01/05/201609:52:39******/SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOALTERPROC[dbo].[ShrinkUser_DATABASESLogFile]ASBEGINDECLARE@DBNAMENVARCHAR(MAX)DECLARE@SQLNVARCHAR(MAX)--临时表保存数据CREATETABLE#DataBaseServerData(IDINTIDENTITY(1,1),DBNAMENVARCHAR(MAX),Log_Total_MBDECIMAL(18,1)NOTNULL,Log_FREE_SPACE_MBDECIMAL(18,1)NOTNULL)--游标DECLARE@itemCurCURSORSET@itemCur=CURSORFORSELECTnamef...
数据库操作教程 2022-09-23 17:41:41 -
SQLServer数据库bcp导出备份文件应用示例
/***授权*/EXECsp_configure'showadvancedoptions',1;goreconfigure;goexecsp_configure'xp_cmdshell',1;goreconfigure;go/**导入指定表的文本文件*/EXECmaster..xp_cmdshell'bcpdbname..tablenameind:DT.txt-c-Sservername-Usa-Ppassword'execmaster..xp_cmdshell'bcp"select*fromdbname..tablename"queryout"D:20140528.xls"-c-Sservername-Uuser-Ppassword'xp_cmdshell参数说明下面是我自己写的一个存储过程,可以直接拿去使用第一步,先要授权。上面有授权的SQL代码ifexists(select*fromsysobjectswheretype='p'andname='sp_export_posm_data')begindropproceduresp_export_posm_data;end;gocre...
数据库操作教程 2022-09-23 17:41:18 -
谈谈sqlserver自定义函数与存储过程的区别
一、自定义函数: 1.可以返回表变量 2.限制颇多,包括 不能使用output参数; 不能用临时表; 函数内部的操作不能影响到外部环境; 不能通过select返回结果集; 不能update,delete,数据库表; 3.必须return一个标量值或表变量 自定义函数一般用在复用度高,功能简单单一,争对性强的地方。二、存储过程 1.不能返回表变量 2.限制少,可以执行对数据库表的操作,可以返回数据集 3.可以return一个标量值,也可以省略return 存储过程一般用在实现复杂的功能,数据操纵方面...
数据库操作教程 2022-09-23 17:33:54 -
使用SQLServer判断文件是否存在后再删除(详解)
在SQLServer中可以使用系统内部存储过程xp_fileexist判断文件是否存在,如果存在再使用xp_cmdshell删除文件。xp_fileexist除了可以判断文件是否存在外,还可以判断文件夹是否存在,下面是下使用这两个的示例...
数据库操作教程 2022-09-23 17:30:10