明天的明天 永远的永远 未知的一切 我与你一起承担 ??

是非成败转头空 青山依旧在 几度夕阳红 。。。
随笔 - 1277, 文章 - 0, 评论 - 214, 阅读 - 321万
  博客园  :: 首页  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

1、自定义4个常用的存储过程:

sp_select :select * from

sp_helpremark :查表的列,列的类型,备注(这里只查询有备注的列)

sp_columns1 : 查表所有的列,列的类型,length

sp_columns2 :查表所有的列,横向显示

注意:上面4个自定义存储过程,必须在查询分析器中执行后,才能快捷键使用。

 

A) sp_select :

CREATE proc sp_select(@sql varchar(1000))    
as    
begin    
set @sql='select * from ' + @sql;    
exec (@sql);    
end 

B) sp_helpremark :

复制代码
CREATE PROC [dbo].[sp_helpremark]      
      
@TABLE_NAME VARCHAR(50)      
      
AS      
      
SELECT COLID,SO.NAME,EP.VALUE,SO.LENGTH,MIN(ST.NAME) AS TYPE      
      
FROM  SYS.EXTENDED_PROPERTIES EP      
      
RIGHT JOIN SYS.SYSCOLUMNS SO ON MAJOR_ID=ID AND COLID=MINOR_ID      
      
LEFT JOIN SYS.SYSTYPES ST ON ST.XTYPE=SO.XTYPE      
      
WHERE      
      
ID=OBJECT_ID(@TABLE_NAME)      
      
GROUP BY COLID,SO.NAME,EP.VALUE,SO.LENGTH      
      
ORDER BY COLID
复制代码

C) sp_columns1 :

复制代码
CREATE PROC sp_columns1      
@table_name VARCHAR(1000)      
AS      
BEGIN      
SELECT a.name,c.data_type,a.length FROM syscolumns  a            
LEFT JOIN information_schema.columns c  ON a.name=c.column_name               
WHERE a.ID = OBJECT_ID (@table_name)            
      
END
复制代码

D) sp_columns2 :

复制代码
CREATE PROC sp_columns2(@table_name VARCHAR(1000))    
AS    
BEGIN    
  
DECLARE @column_name VARCHAR(100)--列名  
DECLARE @columns VARCHAR(1000)--所有列名  
  
SELECT @columns=''  
DECLARE  mycursor cursor  
FOR SELECT name FROM syscolumns WHERE id=(SELECT id FROM sysobjects WHERE name=@table_name)   
OPEN mycursor  
FETCH NEXT FROM  MyCursor INTO @column_name  
 WHILE @@FETCH_STATUS =0  
    BEGIN  
 SELECT @columns=@columns+@column_name+','  
 FETCH NEXT FROM  MyCursor INTO @column_name  
 END  
  
CLOSE MyCursor  
  
DEALLOCATE MyCursor  
  
SELECT @columns  
END    
复制代码

 

 

 

2、打开数据库,工具>>选项>>键盘:

在存储过程列里,填写按快捷键时执行的存储过程(注:这里的存储过程列需要 写入特定的方法名)

 

再根据上面4个自定义的存储过程名称,选择对应不同的快捷键,确定完成。

 

>>>>>>>>>>>>使用方法:

打开查询分析器: 直接写表名,选中,并按目标快捷组合键,完成查询。

 

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
历史上的今天:
2016-03-16 IOS:Safari不兼容Javascript中的Date问题
2011-03-16 SQL:事务处理
点击右上角即可分享
微信分享提示