返回單個值的函數, 可以當變數用, 比如 select dbo.函數名(參數1, 參數2, ...) from ...where abc = dbo.函數名(參數1, 參數2...)
返回表的函數, 可以當數據表來使用, 比如 select * from dbo.函數名(參數1, 參數2, ...)
❷ 幫忙在SQLserver資料庫中創建一個自定義函數funShipFee,用於計算郵寄印刷品的費用
CREATE FUNCTION [DBO].[funShipFee]
( @WG NUMERIC(28,4)--定義重量為數字型
)
RETURNS NUMERIC(28,4)
BEGIN
DECLARE @Value NUMERIC(28,4)--返回的值
DECLARE @REM NUMERIC(28,4)--余數
IF @WG < 100
SET @Value = 0.3
ELSE
BEGIN
SET @Value = 0.3
IF @WG < 5000
BEGIN
SET @REM = @WG % 100
IF @REM <> 0
SET @Value= @Value+(ROUND((@WG-100)/100,0)+1)*0.15
ELSE
SET @Value= @Value+ROUND((@WG-100)/100,0)*0.15
END
ELSE
BEGIN
SET @REM = @WG % 100
IF @REM <> 0
SET @Value= @Value+(ROUND((@WG-100)/100,0)+1)*0.12
ELSE
SET @Value= @Value+ROUND((@WG-100)/100,0)*0.12
END
END
RETURN @Value
END
❸ C#怎麼調用sqlserver的自定義函數
sql server 自定義函數的使用
自定義函數
用戶定義自定義函數像內置函數一樣返回標量值,也可以將結果集用表格變數返回
用戶自定義函數的類型:
標量函數:返回一個標量值
表格值函數{內聯表格值函數、多表格值函數}:返回行集(即返回多個值)
1、標量函數
Create function 函數名(參數)
Returns 返回值數據類型
[with {Encryption | Schemabinding }]
[as]
begin
SQL語句(必須有return 變數或值)
End
Schemabinding :將函數綁定到它引用的對象上(註:函數一旦綁定,則不能刪除、修改,除非刪除綁定)
Create function AvgResult(@scode varchar(10))
Returns real
As
Begin
Declare @avg real
Declare @code varchar(11)
Set @code=@scode + 『%』
Select @avg=avg(result) from LearnResult_jiali
Where scode like @code
Return @avg
End
執行用戶自定義函數
select 用戶名。函數名 as 欄位別名
select dbo.AvgResult(『s0002』) as result
用戶自定義函數返回值可放到局部變數中,用set ,select,exec賦值
declare @avg1 real ,@avg2 real ,@avg3 real
select @avg1= dbo.AvgResult(『s0002』)
set @avg2= dbo.AvgResult(『s0002』)
exec @avg3= dbo.AvgResult 『s0002』
select @avg1 as avg1 ,@avg2 as avg2 ,@avg3 as avg3
函數引用
create function code(@scode varchar(10))
returns varchar(10)
as
begin
declare @ccode varchar(10)
set @scode = @scode + 『%』
select @ccode=ccode from cmessage
where ccode like @scode
return @ccode
end
select name from class where ccode = dbo.code(『c001』)
2、表格值函數
a、 內聯表格值函數
格式:
create function 函數名(參數)
returns table
[with {Encryption | Schemabinding }]
as
return(一條SQL語句)
create function tabcmess(@code varchar(10))
returns table
as
return(select ccode,scode from cmessage where ccode like @ccode)
b、 多句表格值函數
create function 函數名(參數)
returns 表格變數名table (表格變數定義)
[with {Encryption | Schemabinding }]
as
begin
SQL語句
end
多句表格值函數包含多條SQL語句,至少有一條在表格變數中填上數據值
表格變數格式
returns @變數名 table (column 定義| 約束定義 [,…])
對表格變數中的行可執行select,insert,update,delete , 但select into 和 insert 語句的結果集是從存儲過程插入。
Create function tabcmessalot (@code varchar(10))
Returns @ctable table(code varchar(10) null,cname varchar(100) null)
As
Begin
Insert @ctable
Select ccode,explain from cmessage
Where scode like @code
return
End
Select * from tabcmessalot(『s0003』)
來自:http://hi..com/datachina/blog/item/801def0366c4e7ea09fa9344.htmlC#調用SQL自定義函數返回值
代碼
1 --SQL自定義函數:
2
3 CREATE FUNCTION [GetProjectID] (@headStr nvarchar(10),@date datetime)
4 )
5
6 RETURNS NVARCHAR(200)
7
8 AS
9
10 BEGIN
11
12 --不能在自定義函數中用INSERT INTO
13
14 --insert into emos_cust(cust_name,dates)values(
15
16 --@headStr,@date
17
18 --)
19
20 return 'TEST BY HANSHU'
21 END
代碼
1 /// <summary>
2 /// 獲取項目文件編號 塗聚文
3 /// </summary>
4 private void FileNo()
5 {
6
7 SqlConnection conn = new SqlConnection(connectionString);
8 string strSql = "GetProjectID"; //自定SQL函數
9 SqlCommand cmd = new SqlCommand(strSql, conn);
10 cmd.CommandType = CommandType.StoredProcere;
11 cmd.Parameters.Add("@headStr", SqlDbType.NVarChar).Value = "ZQ3"; //輸入參數
12 cmd.Parameters.Add("@date", SqlDbType.DateTime).Value = System.DateTime.Now.ToShortDateString(); //輸入參數
13 cmd.Parameters.Add("@returnString", SqlDbType.NVarChar);
14 cmd.Parameters["@returnString"].Direction = ParameterDirection.ReturnValue; //返回參數
15 try
16 {
17 conn.Open();
18 object o= cmd.ExecuteScalar();
19
20 this.txtAFileNO.Text = cmd.Parameters["@returnString"].Value.ToString();
21
22 //Response.Write("");
23
24 }
25 catch (Exception ex)
26 {
27
28 this.txtAFileNO.Text = ex.Message;
29
30 }
31 finally
32 {
33
34 if (!(conn.State == ConnectionState.Closed))
35 {
36
37 conn.Close();
38
39
40 }
41
42 }
43
44
45 }
❹ 創建SQLServer自定義函數報錯,可是同樣的代碼可以創建過程! 求大神幫忙看看!!!
存儲過程可以 你就建存儲過程唄
你這個 報錯很明顯 函數 不讓你這么干
在函數內對帶副作用的運算符 'SELECT INTO' 的使用無效。
你換個招試試
比如 select count(*)=@v_count as dd from khn_configgroup where config_id=@template_id and group_id=@group_id;
sqlsever函數變數如何賦值我也不是很清楚 沒用過
或者用 set let
❺ SqlServer如何用Sql語句自定義聚合函數
有兩個寫法:
select*fromtblDept
whereidin(
count(casewhenSalary>3000then1elsenullend)*1.0/count(*)>0.5)
或
select*fromtblDept
whereidin(
sum(casewhenSalary>3000then1else0end)*1.0/count(*)>0.5)
❻ SQLServer里用戶自定義函數寫在哪
drop FUNCTION [dbo].[jzf_Get_IDNO]
go
-- =============================================
-- Author: <Author,,Name>
-- Create date: <Create Date, ,>
-- Description: <Description, ,>
-- =============================================
create FUNCTION [dbo].[jzf_Get_IDNO]
(
-- Add the parameters for the function here
@ApartID nvarchar(40)
)
RETURNS nvarchar(40)
AS
BEGIN
-- Declare the return variable here
DECLARE @str nvarchar(40)
set @str=N'未查到'
-- Add the T-SQL statements to compute the return value here
SELECT @str=Isnull(IDNO,N'未定義') from mytable where objectid=@ApartID
-- Return the result of the function
RETURN @str
---------------------結果顯示在,上述函數是標量值函數:
❼ 如何在sql中定義一個函數,函數功能是傳入一個字元串,返回這個字元串中的數
1通過VisualStudio2008新建一個SQLServer項目。2,配置連接的資料庫點擊上一步確定後,可以通過添加新引用來添加一個資料庫連接(只適用MS SQL Server 2005或以上版本,再次提醒哦),添加以後選擇其中一個資料庫點擊確。3,添加一個自定義函數。然後編寫自定義函數的類即可。
用戶自定義函數是指如果要在公式或計算中使用特別復雜的計算,而工作表函數又無法滿足需要,則需要創建用戶自定義函數。
❽ sqlserver里關於自定義函數的問題
應該是調用時沒有傳入參數。
如自定義函數:
create function f_GetString
(@para nvarchar(40))
RETURNS nvarchar(100)
as
begin
declare @s nvarchar(100)
set @s=''
select @s=field1 from table
return @s
end
---------------調用
String sql="select a,b,c,dbo.f_GetString(d) as S from table ..."
如果用
String sql="select a,b,c,dbo.f_GetString() as S from table ..."
會提示函數未傳入參數。
可在查詢分析器中檢驗SQL語句是否正常
❾ SQLSERVER里如何自定義函數
CREATE FUNCTION 函數名 ( @參數1 VARCHAR(10),參數2,int )
RETURNS varchar(30) --返回值及類型
AS
BEGIN
語句
RETURN 結果值
END
❿ sqlserver 自定義聚合函數 sqlserver 2008 有沒有自定義聚合函數的寫法,不要標量值函數和c#的方法。
監聽配置:
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
)
)
我的Oracle監聽及tnsnames.ora所在目錄:C:\app\Administrator\proct\11.1.0\db_1\NETWORK\ADMIN