-
SQL截取字符串函数了解
所属栏目:[MsSql教程] 日期:2021-12-24 热度:121
A.截取从字符串左边开始N个字符 Declare @S1 varchar(100) Select @S1=http://www.xrss.cn Select Left(@S1,4) ------------------------------------ 显示结果: http B.截取从字符串右边开始N个字符(例如取字符) Declare @S1 varchar(100) Select @S1=http:/[详细]
-
SQL语句 一个简单的字符串分割函数
所属栏目:[MsSql教程] 日期:2021-12-24 热度:116
复制代码 代码如下: CREATE FUNCTION dbo.f_splitstr( @str varchar(8000) )RETURNS @r TABLE(id int IDENTITY(1, 1), value varchar(5000)) AS BEGIN /* Function body */ DECLARE @pos int SET @pos = CHARINDEX(,, @str) WHILE @pos 0 BEGIN INSERT @r(val[详细]
-
小议sqlserver数据库主键选取策略
所属栏目:[MsSql教程] 日期:2021-12-24 热度:86
因为主键可以唯一标识某一行记录,所以可以确保执行数据更新、删除的时候不会出现张冠李戴的错误。当然,其它字段可以辅助我们在执行这些操作时消除共享冲突,不过就不在这里讨论了。主键除了上述作用外,常常与外键构成参照完整性约束,防止出现数据不一致。[详细]
-
sqlserver自动增长列引起的问题解决方法
所属栏目:[MsSql教程] 日期:2021-12-24 热度:192
有两个结构完全相同的表,由其中一个表插入另一个表中指定条件的数据,报如下错误: 仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表*中的标识列指定显式值。 在网上找到了解决方案,亲自试过,可以解决。 方法: 复制代码 代码如下: SET IDENTITY_[详细]
-
sqlserver 存储过程动态参数调用实现代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:53
复制代码 代码如下: --创建测试表 CREATE TABLE [dbo].[Student]( [ID] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY, [Name] [nvarchar](20) NOT NULL DEFAULT (), [Age] [int] NOT NULL DEFAULT (0), [Sex] [bit] NOT NULL DEFAULT (0), [Address] [nvarchar[详细]
-
通过分析SQL语句的执行计划优化SQL
所属栏目:[MsSql教程] 日期:2021-12-24 热度:77
如何干预执行计划 - - 使用hints提示 基于代价的优化器是很聪明的,在绝大多数情况下它会选择正确的优化器,减轻了DBA的负担。但有时它也聪明反被聪明误,选择了很差的执行计划,使某个语句的执行变得奇慢无比。此时就需要DBA进行人为的干预,告诉优化器使用[详细]
-
sql数据库批量处理脚本
所属栏目:[MsSql教程] 日期:2021-12-24 热度:114
复制代码 代码如下: DECLARE @T varchar(255), @C varchar(255) DECLARE Table_Cursor CURSOR FOR Select a.name,b.name from sysobjects a, syscolumns b where a.id=b.id and a.xtype=u and (b.xtype=99 or b.xtype=35 or b.xtype=231 or b.xtype=167) OPEN[详细]
-
sqlserver 中时间为空的处理小结
所属栏目:[MsSql教程] 日期:2021-12-24 热度:125
现将几种主要情况进行小结: 一、如何输入NULL值 如果不输入null值,当时间为空时,会默认写入1900-01-01,在业务处理时很麻烦。 ctrl+0即可输入NULL值。 二、如何在sql语句中判断为NULL的时间字段 假设表为:TestTable SN DateTime1 DateTime2 1 2011-10-24[详细]
-
SQL Server Table中XML列的操作代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:93
复制代码 代码如下: --创建测试表 DECLARE @Users TABLE ( ID INT IDENTITY(1,1), UserInfo XML ) ---插入测试数据 DECLARE @xml XML SET @xml= root user userid1/userid userNametest1/userName /user /root INSERT INTO @Users(UserInfo)VALUES(@xml) --插[详细]
-
sql 常用技巧整理
所属栏目:[MsSql教程] 日期:2021-12-24 热度:83
--语 句 功 能 --数据操作 SELECT --从数据库表中检索数据行和列 INSERT --向数据库表添加新数据行 DELETE --从数据库表中删除数据行 UPDATE --更新数据库表中的数据 --数据定义 CREATE TABLE --创建一个数据库表 DROP TABLE --从数据库中删除表 ALTER TABLE[详细]
-
mssql server 数据库附加不上解决办法分享
所属栏目:[MsSql教程] 日期:2021-12-24 热度:138
在QA里执行sp_attach_db或者sp_attach_single_file_db,出现提示:错误1813:未能打开新数据库dbname,create database 将终止。设备激活错误。物理文件名d:sql servermssqldatadbname _log.ldf可能有误! 按下面的步骤处理: 1.新建一个同名的数据库 2.再[详细]
-
SQL Server Bulk Insert 只需要部分字段时的技巧
所属栏目:[MsSql教程] 日期:2021-12-24 热度:183
根据一般做法的话,导出部分字段时没有办法生成格式化XML文件,所以导入时就没有办法格式化导入数据。 我想到两点,1.手工修改格式化XML文件,2.创造一个能生成格式化XML文件的中间对象。 在MSDN中寻找方法时,突然想到可以使用视图来做中间对象,于是就搭一[详细]
-
SQL语句练习实例技巧——找出最近的两次晋升日期与工资额
所属栏目:[MsSql教程] 日期:2021-12-24 热度:178
复制代码 代码如下: --程序员们在编写一个雇员报表,他们需要得到每个雇员当前及历史工资状态的信息, --以便生成报表。报表需要显示每个人的晋升日期和工资数目。 --如果将每条工资信息都放在结果集的一行中,并让宿主程序去格式化它。 --应用程序的程序员都[详细]
-
SQL语句练习实例应用——平均销售等待时间
所属栏目:[MsSql教程] 日期:2021-12-24 热度:63
复制代码 代码如下: ---1.平均销售等待时间 ---有一张Sales表,其中有销售日期与顾客两列,现在要求使用一条SQL语句实现计算 --每个顾客的两次购买之间的平均天数 --假设:在同一个人在一天中不会购买两次 create table sales ( custname varchar(10) not nul[详细]
-
SQL语句练习实例大全——找出销售冠军
所属栏目:[MsSql教程] 日期:2021-12-24 热度:116
复制代码 代码如下: --销售冠军 --问题:在公司中,老板走进来,要一张每个地区销量前3名的销售额与销售员的报表 --- create table salesdetail ( Area int not null, Saler nvarchar(20) not null, SalerId int not null, Sales money not null ) insert sal[详细]
-
sqlserver中如何寻找出连续日期记录的代码
所属栏目:[MsSql教程] 日期:2021-12-24 热度:82
有在论坛上看到一帖,《请教查询出连续日期记录的方法》,截图如下: Insus.NET尝试写了程序并做了测试,可以得到预期的结果,SQL代码可参考和学习之用。 复制代码 代码如下: --创建一个临时表,将会存储连续日期的记录 CREATE TABLE #temp (IDD VARCHAR(10),[详细]
-
SQLserver 数据库危险存储过程删除与恢复措施
所属栏目:[MsSql教程] 日期:2021-12-24 热度:126
今天为了实现SQLServer/ target=_blanksqlserver的复制功能,因为以前删除了很多的sqlserver的一些会导致不安全因素的扩展,导致很多功能无法用,没有办法需要重新的恢复扩展。 曾经遇过,差点抓狂,有装MSSQL的朋友,赶紧试一下,删除以下的组件.当然,前提是你要[详细]
-
insert select与select into 的用法使用步骤
所属栏目:[MsSql教程] 日期:2021-12-24 热度:153
insert into(列名) select 列名 from 表名 where 条件 --不创建表,只复制表数据 select 列名 into 表名(这个表名是不存在的) from 表名 where 条件,--创建一张新表,只复制选择的列名字段数据 Insert是T-sql中常用语句,Insert INTO table(field1,field2,[详细]
-
sqlserver合并DataTable并排除重复数据的通用方法说明
所属栏目:[MsSql教程] 日期:2021-12-24 热度:192
代码如下: 复制代码 代码如下: ///summary /// 将两个列不同的DataTable合并成一个新的DataTable ////summary ///param源表/param ///param需要合并的表/param ///param需要排重列表(为空不排重)/param ///param合并后Table的最大行数/param ///returns合[详细]
-
分析SQL Server删除重复行的6个方法
所属栏目:[MsSql教程] 日期:2021-12-24 热度:193
1.如果有ID字段,就是具有唯一性的字段 复制代码 代码如下: delect table where id not in ( select max(id) from table group by col1,col2,col3... ) group by 子句后跟的字段就是你用来判断重复的条件,如只有col1,那么只要col1字段内容相同即表示记录相[详细]
-
SQL对时间处理的语句分析
所属栏目:[MsSql教程] 日期:2021-12-24 热度:70
复制代码 代码如下: --获取当前时间 Select getdate() --获取当前年月日 YY代表年,MM代表月,DD代表日,hh代表时,ss代表秒 /* year yy 1753--9999 quarter qq 1--4 month mm 1--12 day of year dy 1--366 day dd 1--31 week wk 1--53 weekday dw 1--7(Sunday--S[详细]
-
sqlserver isnull在数据库查询中的作用
所属栏目:[MsSql教程] 日期:2021-12-24 热度:70
isnull在数据库查询中的应用,特别是再语句连接的时候需要用到 比如连接时候,某个字段没有值但是又要左连接到其他表上 就会显示空, isnull可以判断是否是NULL,如果是给个默认值 isnull(字段名,默认的数据) SqlServer中的null值与IsNull函数 NULL 值的三大[详细]
-
SQL建立数据库及删除数据库操作
所属栏目:[MsSql教程] 日期:2021-12-24 热度:115
复制代码 代码如下: CREATE DATABASE 临时的 ON (, FILENAME=h:临时的.mdf, SIZE=5MB, MAXSIZE=50MB, FILEGROWTH=10% ) LOG ON ( NAME=临时的_LOG, FILENAME=h:临时的.ldf, SIZE=2MB, MAXSIZE=5MB, FILEGROWTH=1MB ) 这样就在H盘建立了一个名字为 临时的.md[详细]
-
处理SQL Server的“此数据库没有有效所有者”问题
所属栏目:[MsSql教程] 日期:2021-12-24 热度:150
在附加数据库后查看不了数据库关系图,也无法建立数据库关系图 我的解决方法如下: 1、设置兼容级别为90(2005为90)(2000为80) 复制代码 代码如下: USE [master] GO EXEC dbo.sp_dbcmptlevel @dbname=数据库名, @new_cmptlevel=90 GO [这条命令执行完毕:[详细]
-
sqlserver not in 语句使程序崩溃
所属栏目:[MsSql教程] 日期:2021-12-24 热度:128
两张表 组织架构表(Organise) 和 工资发放历史记录表 (WagePerMonthHis) 两张表通过 Organise.Item_id 和 WagePerMonthHis.OrgIdS 进行关联 Organise表(以下简称O表)中大约有6000条记录11个字段 ,WagePerMonthHis(以下简称W表)计有 125万条记录 和 25个字[详细]