标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 2663 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,725)
- DB2 (22)
- MySQL (74)
- Oracle (1,580)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (160)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (68)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (28)
- Oracle备份恢复 (579)
- Oracle安装升级 (94)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (81)
- PostgreSQL (23)
- PostgreSQL恢复 (10)
- SQL Server (28)
- SQL Server恢复 (9)
- TimesTen (7)
- 达梦数据库 (2)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (37)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (20)
-
最近发表
- 删除redo导致ORA-00313 ORA-00312故障处理
- Navicat连接postgresql时出现column “datlastsysoid” does not exist错误解决
- aix磁盘损坏oracle数据库恢复
- pg误删除数据恢复(PostgreSQL delete数据恢复)
- PostgreSQL表文件损坏恢复—pdu恢复损坏的表文件
- linux rm -rf 删除数据文件恢复
- PostgreSQL恢复工具—pdu恢复单个表文件
- PostgreSQL恢复工具—pdu工具介绍
- 近1万个数据文件的恢复case
- 不当使用_allow_resetlogs_corruption参数引起ORA-600 2662错误
- CSSD signal 11 in thread clssnmRcfgMgrThread故障处理
- 使用sid方式直接访问pdb(USE_SID_AS_SERVICE_LISTENER)
- ORA-00069: cannot acquire lock — table locks disabled for xxxx
- ORA-600 [4000] [a]相关bug
- sql server数据库“正在恢复”故障处理
- 如何判断数据文件是否处于begin backup状态
- CDM备份缺少归档打开数据库报ORA-600 kcbzib_kcrsds_1故障处理
- ORA-07445: exception encountered: core dump [expgod()+43] [IN_PAGE_ERROR]
- 2025年第一起ORA-600 16703故障恢复
- _gc_undo_affinity=FALSE触发ORA-01558
分类目录归档:SQL Server
通过sql server 数据库中的sql语句实现项目需求
最近都关注oracle,今天没有办法,因为项目使用的是sql server数据库,许多东西都忘记的差不多了。需要实现一个功能,本来可以使用程序去实现,但是我不爽,一定想通过数据库本身来解决这个问题。问题大概是:
项目中是要实现在别人寻找到宝贝后,要回答一个问题,这个问题暂时定为有四个选项,其中一个正确的,在数据库中使用两张表来实现,一张是记录问题的题目和答案(表一),另一张表专门用来记录每个题目中的选项(表二),表的sql脚本如下:
USE [xb_new] GO /****** 对象: Table [dbo].[Question] 脚本日期: 06/13/2010 21:17:05 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Question]( [id] [int] IDENTITY(1,1) NOT NULL, [iss_id] [int] NULL, [answer] [nvarchar](50) NULL, [question] [nvarchar](150) NULL, CONSTRAINT [PK_Question_] 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]
表中数据如下:
表二:
USE [xb_new] GO /****** 对象: Table [dbo].[Qusetion_Answer] 脚本日期: 06/13/2010 21:18:12 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Qusetion_Answer]( [id] [int] IDENTITY(1,1) NOT NULL, [qid] [int] NOT NULL, [qtext] [nvarchar](50) NOT NULL, [qvalue] [nvarchar](2) NULL ) ON [PRIMARY]
表中数据如下
现在需求是:把一个题目的四个选项合并到一起,并为了在网页上换行,显示题目,显示答案。
其中难道是行列转换,以前在orcal中都是使用decode来实现的,现在郁闷的sql server中竟然不支持这个函数,只能我在oracle中比较讨厌的case(主要要多写很多when、then、end我不喜欢,而且还容易忘记格 式)来实现。实现sql脚本如下:
SELECT a,q,aa+'<br>'+bb+'<br>'+cc+'<br>'+dd result FROM (SELECT DISTINCT answer a,Question.Question q, aa=MAX(CASE qvalue WHEN 'A' THEN '(A)'+qtext END), bb=max(CASE qvalue WHEN 'B' THEN '(B)'+qtext END), cc=max(CASE qvalue WHEN 'C' THEN '(C)'+qtext END), dd=max(CASE qvalue WHEN 'D' THEN '(D)'+qtext END) FROM dbo.Question,dbo.Qusetion_Answer WHERE qid=dbo.Question.id GROUP BY dbo.Question.answer,Question.Question) temp;
结果如下:
发表在 SQL Server
评论关闭
存储过程实现:更新、插入、删除、再插入
已经在空间上放了好几篇存储过程的东西了,本来这个不想再放上去了,但是想想,为了这个思路的完整性,还是把这个存储过程也给放上来
这次实现的是从回收站还原的功能,整体思路是,先更新所需的档案件号,然后复制到对应的部门表中,然后删除回收站表的数据,再把刚刚到部门表中的数据插入到总表中,使得部门的表和总表数据一致
ALTER PROC [dbo].[add_data_yes] @tablename varchar(30), @id INT, @jh INT AS declare @sql nvarchar(4000) SET @sql=N'update S_del set jh='+CAST(@jh AS VARCHAR(10))+N' where id='+CAST(@id AS VARCHAR(10))+N';INSERT INTO <a href="mailto:%27+@tablename+N%27" target="_blank">'+@tablename+N'</a> ( tm , jh , ajh , gjz , sjms , fsdd , fsrq , zyrw , psz , psrq , tgz , zrz , sc , ly , cjh , srz , flh , dph , bz , xpdx , xpgs , xpxs , scrid , scr , scsj , scbm , shr , shsj , ecbz , gdr , gdsj , xgsj , flag , ysurl , ysfile , xgurl , xgfile , xwurl , xwnr , textall ) SELECT tm , jh , ajh , gjz , sjms , fsdd , fsrq , zyrw , psz , psrq , tgz , zrz , sc , ly , cjh , srz , flh , dph , bz , xpdx , xpgs , xpxs , scrid , scr , scsj , scbm , shr , shsj , ecbz , gdr , gdsj , xgsj , flag , ysurl , ysfile , xgurl , xgfile , xwurl , xwnr , textall FROM S_del WHERE id='+CAST(@id AS varchar(10))+N';delete from S_del where id='+CAST(@id AS varchar(10))+N';insert into S_bm_all select * from <a href="mailto:%27+@tablename+N%27" target="_blank">'+@tablename+N'</a> where id=(select max(id) from <a href="mailto:%27+@tablename+N%27%29%27" target="_blank">'+@tablename+N')'</a> EXEC(@sql)
好了,以前是因为自己对存储过程没有入门,写了几个放在上面了,现在感觉对存储过程有了一点状态,不再放存储过程山来了(我感觉特别有意义的除外)
发表在 SQL Server
评论关闭
存储过程实现:更新、汇总、复制功能
在项目中,要对相片档案资料进行归档(案卷号、件号、题名、归档人、归档日期,归档标示),在归档过程中要用到全文检索(用一个字段保存全文实现),把该数据从部门表复制到总表中,即要实现更新、汇总、复制功能于一体的存储过程:
ALTER PROC [dbo].[guidang] @tablename varchar(30), @id int , @tm varchar(500), @jh int, @t DATETIME , @ajh INT, @gdr VARCHAR(10) AS DECLARE @sql VARCHAR(2000) SET @sql='update <a href="mailto:%27+@tablename+%27" target="_blank">' +@tablename+'</a> set flag='''+CAST(3 AS VARCHAR(1))+''',gdr='''+@gdr+''', gdsj='''+CAST(@t AS VARCHAR(25))+''',jh='+CAST(@jh AS varchar(10))+', ajh='+CAST(@ajh AS VARCHAR(10))+',tm='''+@tm+''',textall=tm+'+ '''|'''+'+isnull(gjz,'''')+'+'''|'''+'+isnull(gjz,'''')+'+'''|''' +'+isnull(fsdd,'''')+'+'''|'''+ '+isnull(zyrw,'''')+'+'''|'''+'+isnull(psz,'''')+'+'''|''' +'+isnull(tgz,'''')+' +'''|'''+'+isnull(zrz,'''')+'+'''|'''+'+isnull(srz,'''')+' +'''|'''+'+isnull(bz,'''')+'+'''|'''+'+isnull(scr,'''')+'+'''|'''+ '+isnull(shr,'''')+'+'''|'''+' +isnull(gdr,'''')where id='+CAST(@id AS VARCHAR(10))+';insert into S_bm_all select * from <a href="mailto:%27+@tablename+%27" target="_blank">' +@tablename+'</a> where id='+CAST(@id AS VARCHAR(10)) EXEC(@sql)
在这个编写过程中,如果汇总项中,有一项为null,就会得到textall为null,这个困惑了我很久,最后发现了问题在这,用isnull函数解决问题,还有一个细节问题,“‘”有表示转义的意思
发表在 SQL Server
评论关闭