找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
發表文章前請先閱讀相關版規尊貴會員無限下載附件搞笑、娛樂、精彩的影片讓你看
三上cosplay鬼父中出kkbox
韓國演藝atid 397情欲の古異物baelz裸の王羅莉

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

(4月新番)[簡]怪異與

(4月新番)[繁]狼與辛

[繁]怪異與少女與神隱

[繁]The Grimm Variat

[繁]我的英雄學院 Mem

中和廣福路 不滿轎車
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1981|回復: 8
打印上一主題下一主題

[問題]關於where 後的條件 可否用變數代替 (急件)[複製鏈接]

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
跳轉到指定樓層
樓主
發表於 2010-3-30 11:32 AM|只看該作者|倒序瀏覽
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
本帖最後由 v27142714 於 2010-3-30 11:51 AM 編輯

原本的程式 如果是這樣

  1. select * from A where a='ssss'
複製代碼
我想問 可否變成

  1. declare @s varchar(10)
  2. set @s = 'a='ssss''

  3. select * from A where @s
複製代碼
我當然知道我的語法是錯得離譜
不過意思大概就是這樣子
因為我遇到的問題是 我需要傳參數進來做判斷
偏偏是複選的 所以參數條件不只一個
如果寫成if else 之類的程式碼太過長了 原本單一條件已經跑得喘吁吁
所以想把條件變成變數 單獨拉出來判斷
我想請大大指教 該改哪裡呢 謝謝

Best Regard
2010/03/30...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。

使用道具檢舉

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
頭香
發表於 2010-3-30 11:38 AM|只看該作者
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。
本帖最後由 v27142714 於 2010-3-30 11:52 AM 編輯

(嘿嘿 清除乾淨了@@ )


不好意思 我不知道按到什麼 跑出上面那些東西 砍不乾淨@@

礙到大大視覺  先說一下抱歉喔  sorry
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

  專 家(12000/24000)

落葉知秋

Rank: 5Rank: 5Rank: 5Rank: 5Rank: 5

帖子
1600
積分
23884 點
潛水值
54991 米
3
發表於 2010-3-30 12:08 PM|只看該作者

使用道具檢舉

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
4
發表於 2010-3-30 12:42 PM|只看該作者
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
挖 VB版大耶
我講清楚一點好了
我需要這樣做的原因是
我需要傳參數到stored procedure
由於條件是複選的 例如來源A B C
我要可以選擇篩選 A或B或C或AB或AC或BC或ABC
所以不能寫死成 where source = @s
突發奇想 想把整段source = A and source = B 之類的 串成一個字串 @s
直接變成 where @s
另外 也許會想說 為什麼不考慮做整段程式的if else
因為....跑不動 程式碼變成七倍長 太長了
...
瀏覽完整內容,請先 註冊登入會員
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
5
發表於 2010-3-30 01:17 PM|只看該作者
回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
arthurliuliu



好像頗有難度

是不是寫成
  1. select * from A
  2. where a IN (@s)
複製代碼
如果是一個條件
set @s = 'AA' 是OK

那如果是多條件

set @s = 'AA','BB'

兩個條件該如何包起來呢...
瀏覽完整內容,請先 註冊登入會員





使用道具檢舉

  專 家(12000/24000)

落葉知秋

Rank: 5Rank: 5Rank: 5Rank: 5Rank: 5

帖子
1600
積分
23884 點
潛水值
54991 米
6
發表於 2010-3-30 10:18 PM|只看該作者
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。
  1. select *
  2. from table
  3. where
  4. field in ('US','JP','CN','TW');
複製代碼


select... from... where... in... 的語法大概是這樣,
然後你只要把 () 內的東西弄成變數就可以了。
新手就更該多用「心」動「手」找答案;
經驗是累積來的,答案則是 Google 來的。
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
7
發表於 2010-3-31 08:38 AM|只看該作者
回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
arthurliuliu



這個我昨天有稍微試出來,不過好像限用於and串接

如果要用 不等於 的話 該怎麼辦呢

要寫成兩個CASE 一個用IN 一個用NOT IN嗎

像我還有七個選項要複選的  
...
瀏覽完整內容,請先 註冊登入會員
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

帖子
1024
積分
0 點
潛水值
17419 米
8
發表於 2010-4-5 11:45 PM|只看該作者
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。
mysql 嗎?
建議你還是不要這樣作好了, mysql 的store function 並不成熟
乖乖用 php 吧
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。

使用道具檢舉

Rank: 1

帖子
488
積分
57 點
潛水值
73 米
9
發表於 2010-4-6 09:08 AM|只看該作者
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。
回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
alpe



喔~~是SQL SERVER 唷 沒有過PHP
不過我是要寫stored procedure
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部