當前位置:首頁 » 編程語言 » sql變數select

sql變數select

發布時間: 2022-05-23 07:40:43

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、備用變數(判斷優秀的條件)程序收到返回值時判斷後輸出提示。
如果不知道多少分為優秀,則可以多加一個傳入變數,將判斷是否優秀的分值也從變數代入。

熱點內容
php房產網 發布:2025-02-13 18:18:06 瀏覽:85
源碼資源吧 發布:2025-02-13 18:14:39 瀏覽:79
java培訓價錢 發布:2025-02-13 17:59:33 瀏覽:974
c語言中變數類型 發布:2025-02-13 17:52:20 瀏覽:258
ftp導出報錯 發布:2025-02-13 17:41:20 瀏覽:997
腳本下載教程 發布:2025-02-13 17:39:06 瀏覽:235
解壓密碼re 發布:2025-02-13 17:39:02 瀏覽:558
linuxdump內存 發布:2025-02-13 17:37:30 瀏覽:57
游戲客戶端源碼 發布:2025-02-13 17:37:19 瀏覽:594
win7打開文件夾聲音 發布:2025-02-13 17:35:03 瀏覽:606