sql變數select
A. sql中select返回變數的問題
使用游標遍歷,一個一個去取。
下面的例子希望可以幫到你。
declare cursor1 cursor for --定義游標cursor1
select * from table1 --使用游標的對象(跟據需要填入select文)
open cursor1 --打開游標
fetch next from cursor1 into @id--將游標向下移1行,獲取的數據放入之前定義的變數@id中
while @@fetch_status=0 --判斷是否成功獲取數據
begin
print @count --進行相應處理(跟據需要填入SQL文)
fetch next from cursor1 into @id--將游標向下移1行
end
close cursor1 --關閉游標
deallocate cursor1
B. Sql語句中的select語句。在ms sql server中。對變數賦值
問題1:這句式是常用的,如果給變數賦的值不是單一而是結果集的話
只會賦值最後一條數據,不會報錯;通常如果要一條一條的賦值來執行其他操作的話
是要用到游標的
問題2:你想的語句是錯誤的,因為select
@name
=name
from
table
1
where
id
=『123』
只是賦值語句,而不是真正意義上的查詢語句,所以語句將不會執行
C. 在SQL 查詢語句里,select from 變數
比如要查詢A表的數據:
declare @table varchar(20) ,@sql varchar(20)
set @table='A'
set @sql='select * from '+@table
exec (@sql)
你上面的語句明顯是錯誤的,select * from @m其中的@m是個變數應該是個表名
D. sql server select 多個變數
這個有倆種寫法:
1: insert into A1(id) select id from T where id=1
insert into A2(id) select id from T where id=2
....
2:使用 exec拼接,這種方法需要看具體實現情況了 ,比如做個循環
exec('insert into '+@a+'(id) select id from T where id='+@id)
E. Sql中的set和select賦值方式的區別
最近的項目寫的SQL比較多,經常會用到對變數賦值,而我使用SET和SELECT都會達到效果。
那就有些迷惑,這兩者有什麼區別呢?什麼時候哪該哪個呢?
經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別:
假定有設定變數:
復制代碼 代碼如下:
DECLARE @VAR1 VARCHAR(1)
DECLARE @VAR2 VARCHAR(2)
1、SELECT可以在一條語句里對多個變數同時賦值,而SET只能一次對一個變數賦值,如下:
復制代碼 代碼如下:
SELECT @VAR1='Y',@VAR2='N'
-- 而SET要達到同樣的效果,需要:
SET @VAR1='Y'
SET @VAR2='N'
/*
說到這個,SQL內置的變數:@@ERROR 和 @@ROWCOUNT必須要在一句SQL語句中捕獲。如果用set分兩句來獲取它們,將獲取不完整,這時就應該用select來獲取值。
*/
2、表達式返回多個值時,用SET將會出錯,而SELECT將取最後一個值,如下:
復制代碼 代碼如下:
----以下假定Permission表有多個IsRight記錄
SELECT @VAR1 = IsRight FROM Permission --將取最後一個值
SET @VAR1 = IsRight FROM Permission --將報錯
3、表達式無返回值時,用SET將置變數值為NULL,用SELECT交保持變數值,如下:
復制代碼 代碼如下:
----以下假定Permission記錄為空
SET @VAR1 = '初始值'
SELECT @VAR1 = IsRight FROM Permission --此時@VAR1為'初始值'
SET @VAR1 = (SELECT IsRight FROM Permission) --此時@VAR1為NULL
4、使用標量子查詢時,如果無返回值,SET和SELECT一樣,都將置為NULL,如下:
復制代碼 代碼如下:
----以下假定Permission記錄為空
SET @VAR1 = '初始值'
SELECT @VAR1 =(SELECT IsRight FROM Permission ) --此時@VAR1為NULL
SET @VAR1 = ( SELECT IsRight FROM Permission) --此時@VAR1為NULL
F. sql中,select定義怎樣使用變數
你這是語法錯誤了,from 後面是表,你聲明的變數是varcher,要聲明表變數;
怎樣實現select語句中[資料庫名].[結構類型].[表名]為局部變數?
你可以這樣:select @hisDB = temp.[DSN] FROM (select @masterDB as [DSN])temp
G. SQL裡面怎麼用 select 變數 from 表名 的方式動態指定欄位名
SQL裡面怎麼用 select 變數 from 表名 的方式動態指定欄位名
//定義查詢出來的欄位名@f_name
declare @f_name varchar(50)
//給@f_name賦值
select @f_name=f_name from table_name
//執行拼接的sql語句
exec (N'select '+@f_name + N' from table_name')
//這3步必須一起執行
//在2008r2版本測試通過
H. sql server 2000 如何把select的值賦給一個變數
直接使用 = 號可以賦值,如圖把a列的值賦給變數 @name
需要注意:
1、sql中 使用 declare 聲明 變數,變數要以@開頭。
2、如果是直接賦值使用set ,如: set @name = 'name'
3、select 子句中賦值,需要注意結果集,如第一個例子中,
select @name = a from a (去除了 id=2的篩選),那麼結果集為多條記錄
那麼@name 接收的值是結果集最後一條記錄中 a列的值。
I. SQL中的SELECT命令的功能是
從表或視圖中檢索符合條件的數據。
select後面跟的是數據項列表
J. sql 存儲過程 select怎麼返回變數值
存儲過程可以定義兩個變數:1、傳入變數(學號);2、返回變數(0和1);3、備用變數(判斷優秀的條件)程序收到返回值時判斷後輸出提示。
如果不知道多少分為優秀,則可以多加一個傳入變數,將判斷是否優秀的分值也從變數代入。