sql如何解析存儲
以參數傳入存儲過程的數值都會被解析為字元串,所有的關鍵字都會被轉義,所以如果想實現你想要的那個效果就要先定義sql語句,然後根據參數生成,再執行,如下:
declare @sSql varchar(1000)
set @sSql=『select * from T1 where ID in (『+@DepartmentId+』)』
exec (@sSql)
註:此處sSql 就相當於sql語言中的字元串,只不過連接符是單引
❷ 如何導出SQL的視圖和存儲過程
打開SQL按F7,調出「對象資源管理器詳細信息」,在左側選中「存儲過程「或」StoredProceres「目錄,到右側窗口,全選所有的要導入的sp,在選中的sp上滑鼠右鍵。「生成存儲過程腳本為」->「Drop和Create到」->「File」,這樣就可以導出所了。
❸ 談談如何從本質上理解sql語句, 存儲過程,ORM之間的聯系和取捨。
所以我們需要來理解這些技術的本質。一,演變 剛開始的時候,只有sql語句,即可以用交互模式一句一句執行, 也可以用批模式執行,多行sql語句一次提交執行。 很快人們發現用批模式執行的一堆sql語言可以用過程的形式,事先存放到資料庫裡面,這就變成了存儲過程。 隨著面向對象技術的成熟,從程序中可以自動生成sql語句,這就是ORM 二,性能 很多人會說存儲過程比sql語句性能好,其實這個說法並不精確。 如果我們把一堆sql,以批的方式一次送入到伺服器,那麼伺服器,會對這一堆sql進行緩存,當下一次再度執行的時候,就好像調用一個」匿名「的存儲過程一樣。在這種情況下,性能差不多。 但是,如果我們不注意,很有可能,把可以一次提交的sql,變成了多次提交,甚至是每個循環做了一次提交,那麼性能就很差了。 也就是說如果使用sql,只要寫法得當,性能和sp區別不大。 同樣的道理,ORM的性能取決於ORM的Sql生成演算法, 和用戶使用的時候,對生成演算法的控制,比如利用好Lazy laoding等,在某些情況下,甚至可以不通過sql,畢竟沒有sql比最優化的sql還要快。三,可維護性 可維護性是選擇sql,sp,orm最主要的因素。 這裡面有點」玄「,因為不同的場景會得出不同的結論,俗稱「It depends" 剛開始的時候,sql的維護性看起來是最差,因為它往往散布在程序的每個角落。而存儲過陳都放在資料庫中,有清晰介面。 但是如果我們做一次重構,情況居然會顛倒過來。 首先,存儲過程完全可以照搬到C#中,sp的名字直接變成method的名字,sp的參數表直接變成method的參數表,(其實就是Command模式)。 其次,把這些methdod放到一個文件或者文件夾中。(所謂的DAL層,如果喜歡層的話) 通過這個重構,我們獲得了以下的好處, 1,首先是過程的調用和過程的定義放到了一起,修改起來比較方便。IDE都有定義跳轉功能。 2,過程的調用和定義同時進行版本控制,不會出現不匹配的情況。減少了sp的參數表和調用的不匹配,包括拼寫,類型,參數次序 3,單元測試非常方便 當然sp也有存在的價值,比如所謂的安全性,後面會提到。比如友好的調試環境,對於中小型項目,和初級程序員來說,也是很好的選擇。 ORM則將可維護性提升身到了一個新的高度,它試圖將sql屏蔽起來,在操作對象的同時,自動就把資料庫的事情給辦了。 ORM有兩種模式,一種是ActiveRecord, 一種是Datamapper,前者從資料庫中讀取定義,後者在程序中定義。不過由於前者往往用migration來生成資料庫,其實也是定義在程序裡面的。好的ORM都有"leaking"的設計,也就是留了個」後門「,讓你有機會用sql來控制。 微軟的linq從某個角度類說,也是一種ORM, 它的設計思想可能是因為它覺得寫sql語句比寫c#代碼效率高,所以提供直接在C#中寫sql語句的機制,再自動生成真正的sql。不過,ORM真正價值在於它可以在恰當的時候,完全拋棄sql,比如比如讀用cache,寫用queue。而微軟的linq,完全是「無厘頭」的風格,在O中用R的寫法,難道是RRM, 唯一的好處只是鎖定程序和程序員在微軟的平台上。 三,安全性 對企業來說,安全性有的時候比性能更重要,由於存儲過程在資料庫上多加了一道屏障,所以很多企業會把存儲過程作為首選。 ORM可以說是安全性最差的, 因為只有到程序運行起來,你才能知道,會產生什麼樣的sql。 但是保證安全有許多方法和方面,比如部署前的測試, 資料庫的備份,對表的許可權的設置。等。用sp來保證安全,只是多個選項中的一個。 在startup型企業中,高級程序員往往起到主導作用, 所以他們會不猶豫的選擇ORM。
❹ 如何使用SQL語句查看存儲過程的內容
有時候你沒有辦法使用圖形界面的管理器連接SQL 伺服器,這個時候如果你想查看一個存 儲過程的內容就只能依靠SQL 語句了。 系統提供了一個存儲過程可以查看 rule,stored procere, user-defined function, trigger, 或者 view。Syntaxsp_helptext @objname = 'name' sp_helptext '存儲過程名稱'
❺ 如何在SQL Server 2008下輕松調試T-SQL語句和存儲過程
今天突然有同事問起,如何在sqlserver中調試存儲過程(我們公司使用的是sqlserver 2008 R2),猛地一看,和以前使用sqlserver 2000真的有很大的不同,我真暈了。
於是琢磨了一下。SQLSERVER 2005中不知因何去掉了很重要的DEBUGGER功能,要調試,必須要安裝VS2005專業版或者更高版本。非常不方便。
還好,SQLSERVER 2008中這個很重要而且方便的功能又回來了。
不過,SQLSERVER 2008的調試功能和SQL2000的方法差別很大。SQL2000是在查詢分析器中的對象瀏覽器中選中需要調試的存儲過程,右鍵----調試---輸入參數開始調試。
sqlserver2008中則完全不同,變成了必須要在SSMS中EXEC [PROCEDURE NAME] @VAR1,@VAR2,然後點綠色三角或者點菜單中的調試---啟動調試。然後點工具欄的最右邊的單步調試或者跳出等。下面的變數窗口和堆棧窗口等可以查看調試中變數等動態變化值。
sqlserver2008調試的要求和條件:如果在引擎所在的電腦或伺服器上調試,則只需要SA或者WINDOWS用戶登陸即可。如果是異地調試,則需要設置防火牆例外,增加SSMS和SQLSERVER.EXE為允許,增加135埠允許通過。
總之,SQL2008的調試比2000操作起來麻煩多了,要求也多了。剛開始感覺不如2000的好用,也可能是使用2000習慣了。習慣是可怕的,但是微軟是在不斷進步的...
一、回顧早期的SQL SERVER版本:
早在SQL Server 2000時代,查詢分析器的功能還很簡陋,遠不如VS那麼強大。到SQL Server 2005時代,代碼高亮、SQL優化等功能逐漸加強,但是依然無法調試SQL語句。好一點的第三方的SQL語法編輯器似乎也不夠完美,這樣導致一些人抱怨存儲過程不便於維護,開發的時候能不用則不用。
二、SQL Server 2008 Express 智能提示加強:
該功能是SQL2008在SQL Server 2005之後的升級版,我們可以很方便的調用智能提示,和 VS一致:使用快捷鍵ctrl + J 即可。
截圖如下:
❻ SQL中怎樣用查詢分析器獲取存儲過程的源代碼
exec sp_helptext '存儲過程名'
❼ sql存儲過程解釋
CREATE PROCEDURE dbo.AddOrder
創建存儲過程AddOrder
/*
(
@parameter1 int = 5,
---參數1,int類型,默認值是5
@parameter2 datatype OUTPUT
---參數2,datatype類型,用於返回結果
)
*/(
---上面兩個參數被注釋掉了,也就是沒有用了。
@UserID int,
---參數 UserID,int類型
@CartIDString nvarchar(50),
---參數CartIDString,string類型
@OrderDate datetime,
---參數 OrderDate datetime類型
@OrderID int output)
---參數 OrderID,int類型,用於接收輸出值
AS
---開始存儲過程主體
begin tran OrderAdd
---開始事務處理
insert into Orders -------
( |
UserID, |
OrderDate) |
values |
(@UserID, |
@OrderDate) ------------- 到這里是插如一條數據到Orders表
select
@OrderID=@@Identity ------給OrderID賦值
insert into OrderContent -----開始插入數據到OrderContent表
(OrderID,
BookID,
BookQuantity,
UnitCost) -------設定要插入的4個欄位
select @OrderID,
ShopCart.BookID,
bookquantity,
books.bookprice ------設定要選擇的4個欄位
from
shopcart ------結合shopcart和books進行條件查詢
inner join books on shopcart.bookid=books.bookid
where
cartidstring=@cartidstring ----插入語句到此結束
exec emptyshoppingcart @cartidstring ---此處應該是執行了另外一個存儲過程
commit tran orderadd ---- 事務處理結束。
註:此存儲過程並不復雜,有難度的地方在第一條插入語句嵌套了使用了inner join的選擇語句。
❽ SQL的數據存儲過程如何使用
在sql裡面要執行該存儲過程的話就用EXEC
存儲過程名;如果你的存儲過程帶有參數的話在執行的時候還要在存儲過程名的後面加空格在家參數;
例如創建存儲過程:
CREATE
PROCEDURE
getStuInfo
@Id
INT
AS
SELECT
*
FROM
Student
WHERE
Id
=
@Id
執行該存儲過程:
EXEC
getStuInfo
'101'
這段查詢語句的意思是從學生信息表中查詢出編號為101的學生的所有信息
sql資料庫里的存儲過程還可以在c#窗體應用程序里調用,這就涉及到連接資料庫了,如果你需要的話我可以格尼一段代碼示例
❾ SQL SERVER 如何應用存儲過程呢操作方法有什麼呢
SQL SERVER 如何應用存儲過程呢?
首先最好在SQL SERVER的管理工具中通過create procere寫一條語句來創建存儲過程,創建語句後,點擊工具欄中的執行命令,消息欄中顯示命令已成功完成的消息,證明存儲過程已創建。然後就可以在存儲過程子文件夾下看到自己創建的存儲過程了,執行存儲過程,可以使用exec命令,後跟存儲過程的名稱,另外,還可以在創建存儲過程的時候傳入參數,如下圖,需要使用@符號傳入參數,如果你的存儲過程加了參數,那麼如果你調用的時候沒有傳入參數,SQL SERVER會提示錯誤。
3、存儲過程減少網路流量對於資料庫對象的相同操作,如果將此次操作所涉及的T-SQL語句組織成一個存儲過程,在客戶端調用該存儲過程時,只在網路上傳遞調用語句,否則會是多條 SQL 語句。從而減輕了網路流量,降低了網路負載存儲過程可以用作安全機制,系統管理員可以對要執行的存儲過程的許可權進行限制,從而限制對某些數據的訪問,避免未經授權的用戶訪問數據,保證數據安全。