談一談在工作過程中搜集的.NET小工具小程序 數據庫腳本工具 VS2010/2012風格的界面框架


工作中遇到的問題,經常會在網絡上搜集一些相關的內容,以此擴展以解決相同性質的問題,StackOverflow,CodeProject,CodPlex是我經常查找內容的網站。以下分享我找到的一些比較有典型意義的程序,列舉工作中中可以能會遇到的場景和解決方法。

SQL Server Runner

網址:http://www.codeproject.com/Articles/22882/SQL-Server-Runner-Part-1 

分類: 數據庫實用工具

工作中經常會遇到,新增表或新增字段,像下面的SQL語句片段這樣

IF NOT EXISTS(SELECT C.NAME FROM DBO.SYSCOLUMNS C, DBO.SYSOBJECTS O WHERE O.ID = C.ID AND  O.NAME = 'PRSBPN' AND  C.NAME = 'X')

BEGIN
    Alter table [PRSBPN] add [Y_UOM]      [nvarchar](4)
End
GO
在自己的電腦上,可以用SQL Server Management Studio的Table Designer來設計,但是到了客戶那邊,不太可能有機會啟動表設計器來添加字段,於是需要一個工具,把自己生成的字段變成SQL語句,客戶那邊只需要運行一個SQL語句,即可完成添加表和字段的動作。

image

SQL Server Runner可以運行指定的目錄中的SQL語句,這一點就可以滿足我的需求。使用方法也很直觀,打開數據庫連接,選定數據庫,選擇要運行的SQL文件所在的目錄,然后執行(Run Scripts)即可。額外的,SQL Server Runner可以把當前的數據庫連接,SQL文件目錄位置等信息保存起來(xml文件),下次有SQL更新時,把更新后的SQL語句拷貝到指定的目錄中,再運行SQL Server Runner打開原來的項目文件,運行一次即可。

CodeProject中另有一個相同作用的功能的,Generating osql Batch Scripts,它爭對指定的目錄,生成一個OSQL的批處理文件,再通過運行這個批處理文件以達到更新數據庫的目的。

image

可以這樣調用它的源代碼

OsqlScript oscript = new OsqlScript("C:\\scripts",
                          "C:\\scripts\\ExecuteScripts");
oscript.Server = "MyServer";
oscript.Database = "Northwind";
oscript.UseIntegratedSecurity = true;
oscript.UseReportFile = true;
oscript.ReportFile = "Report.txt";

//generate the file
oscript.Generate();

VS 2010/2012 Look-like 界面框架

網址: http://www.codeproject.com/Articles/551885/How-to-create-a-VS-2012-like-application-Wide-IDE

分類:界面框架

經常會做一點小工具,小源碼,不可避免的要選擇一些界面框架來完成任務。VC++ 6時,Document/View文檔/視圖結構,C# 2.0時,經常選MDI,再到后來,Tab MDI,再后來,Office Ribbon,界面框架在不停演化,使它看起來更美觀,更有利於表達軟件的功能。Visual Studio出來之后,有大量的軟件模范其界面,用關鍵字Visual Studio Look-like搜索,可以找到相關內容,以實現模范Visual Studio界面風格的界面框架,這里介紹Wide IDE Framework。

先來上兩張圖,以看看它的效果

VS 2012 風格的界面

image

VS 2010風格的界面

image

效果實現的相當不錯,Wide框架也引用到一 些第三方的開源類庫,列舉如下

如果想讓你的工具界面看起來更漂亮一些,可以考慮試驗一下這些開源的組件。License許可為GNU,

The GNU Lesser General Public License (LGPLv3)

 

Office 2007 ToolStrip Render   Office 2007 Blue風格的工具條

網址: http://www.codeproject.com/Articles/16666/Office-2007-ToolStrip-Renderer

分類: 界面框架

只需要三個cs文件,你的程序中的tool strip就可以變成Office 2007 Blue風格,藍色的背景看起來有些專業。

上個圖,我做的小工具界面,集成了一些常用的工具程序,重點是它的Office Blue風格。

image

使用它的方法也簡單,以下二行代碼即可:

ToolStripManager.Renderer = new Office2007Renderer();
statusStrip.Renderer = new Office2007Renderer();

 

Script SQL Server Data 把SQL Server數據變成SQL腳本

網址:http://www.codeproject.com/Articles/5598/Generating-INSERT-statements-in-SQL-Server

分類: 數據庫實用工具

經常遇到一些問題,在客戶的地方,因為有問題,而在我們這邊沒有問題。經過我折騰多次的經驗,還是直接拿客戶的數據庫過來測試,這樣靠譜一些,也容易定位問題。但有時候,客戶的數據庫很大,有100GB以上,即使用WinRAR壓縮一下也有10G,刻成DVD,再經過快遞公司送到開發部這邊來,時間上要延遲一下,而且不是每次出問題,都要這樣。一方面是要為程序建立跟蹤機制,可以跟蹤程序的數據輸入輸入,堆棧調用,另一方面,如果是數據庫的問題,需要把有問題的數據打包,傳回來試一下。整個數據庫打包有點不現實,那就要只把可疑的數據打包,變成SQL傳到開發部來。下面介紹的工具,就是實現這個目的。

image

Table Insert Statements可以把存儲在表中的數據,變成SQL語句文本文件。因為在很多場景中,這個功能實在太需要了,於是我做出一個增強版的Query Generator,以滿足數據轉移的需求。

image

與CodeProject中不同的地方,我可以擇需要的數據行生成SQL語句,還可以選擇字段。選擇字段這個功能有相當重要的作用,比如數據表有一個字段是種子類型(identity),一般情況下是不能給種子類型插入數據,請看MSDN中的例子

USE AdventureWorks2008R2;
GO
-- Create tool table.
CREATE TABLE dbo.Tool(
   ID INT IDENTITY NOT NULL PRIMARY KEY, 
   Name VARCHAR(40) NOT NULL
)
GO
-- Inserting values into products table.
INSERT INTO dbo.Tool(Name) VALUES ('Screwdriver')
INSERT INTO dbo.Tool(Name) VALUES ('Hammer')
INSERT INTO dbo.Tool(Name) VALUES ('Saw')
INSERT INTO dbo.Tool(Name) VALUES ('Shovel')
GO

-- Create a gap in the identity values.
DELETE dbo.Tool 
WHERE Name = 'Saw'
GO

SELECT * 
FROM dbo.Tool
GO

-- Try to insert an explicit ID value of 3;
-- should return a warning.
INSERT INTO dbo.Tool (ID, Name) VALUES (3, 'Garden shovel')
GO
-- SET IDENTITY_INSERT to ON.
SET IDENTITY_INSERT dbo.Tool ON
GO

-- Try to insert an explicit ID value of 3.
INSERT INTO dbo.Tool (ID, Name) VALUES (3, 'Garden shovel')
GO

SELECT * 
FROM dbo.Tool
GO
-- Drop products table.
DROP TABLE dbo.Tool
GO

腳本解釋了當要為種子類型字段直接插入值時,要設計它為IDENTITY_INSERT為ON,之后如果要能讓SQL Server自動插入種子值,又要設為OFF。

如果上在面的腳本生成工具中,我把種子類型的列去掉,不生成它的數據,問題就容易多了,根本不用考慮設置IDENTITY_INSERT。從設計意義上來說,IDENTITY類型常常用來維護數據,它是唯一的,對數據庫資料的維護,數據間的對比,有重要的意義。ERP數據表中,主檔表,日記帳表,每個表都給它加上這個類型,在ERP維護時,有很好的作用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM