『壹』 PL/sql中如何聲明及使用動態游標
oracle動態游標問題: 游標查詢的內容是 動態生成的,然後裡面具體有多少個欄位沒辦法事先知道,而動態游標賦值一定要用fetch到一個變數,有沒辦法把動態游標內容賦值到一個記錄集或者表中,而這個表的欄位和記錄集欄位是沒辦法預先定義好的,而是通過系統動態生成的!
具體例子如下:declare-- Local variables here
v_sql VARCHAR2(1024);
cur SYS_REFCURSOR;
v_column VARCHAR2(1024);
v_exe VARCHAR2(1024);begin---v_sql 是通過一連串的復雜邏輯程序生成的動態內容的 在這里就簡單寫了
v_sql:='select C_001,b_002,d_003 ..../*具體有多少個欄位沒辦法事先知道*/from table1,table2 .../*具體有多少個欄位沒辦法事先知道*/tablen where 1=1 and /*復雜條件*/';
v_column:= 'C_001+b_002/d_003';--這個變數也是通過復雜的邏輯生成的 沒辦法事先知道的 但是這里的欄位都在 v_sql 中有
v_column := replace(replace(REPLACE(v_column,'b_','c.b_'),'c_','c.c_'),,'c_','c.d_');
FOR i IN 1..e_table(i);
v_exe:='INSERT INTO table_a SELECT'|| v_column||' FROM al' ; /*這里的動態生成的*/!
『貳』 sql怎麼聲明 變數
聲明局部變數語法:DECLARE @variable_name DataType其中 variable_name為局部變數的名稱,DataType為數據類型。
給局部變數賦值有兩種方法:
1、SET @variable_name=value
2、SELECT @variable_name=value
兩者的區別:SET賦值語句一般用於賦給變數一個指定的常量,SELECT賦值語句一般用於從表中查詢出數據然後賦給變數。
例如:DECLARE @count int
SET @count=123
PRINT @count
全局變數:由於全局變數是系統定義的,我們這里只做舉例。
@@ERROR 最後一個T-SQL錯誤的錯誤號
@@IDENTITY 最後一次插入的標識值
@@LANGUAGE 當前使用的語言名稱
@@MAX_CONNECTIONS 可以創建的同時連接的最大數目
@@SERVERNAME 本地伺服器的名稱
@@VERSION SQL Server的版本信息
『叄』 sql 存儲過程中 如何使用declare 有的存儲過程聲明了,有的沒有聲明。請回答的詳細點。。謝謝
存儲過程既可以有declare語句,也可以沒有,declare聲明的是一個語句塊,是pl/sql執行的基本單位,
案例:一個基本的declare語句塊
DECLARE
e_invalid_departmentEXCEPTION;--聲明部分,給例外命名
BEGIN
UPDATEdepartments
SETdepartment_name='OracleTechnologyCenter'
WHEREdepartment_id=60;
IFSQL%NOTFOUNDTHEN
RAISEe_invalid_department;--程序執行部分,使用raise語句顯示拋出例外
ENDIF;
COMMIT;
EXCEPTION
WHENe_invalid_departmentTHEN--例外處理部分,處理拋出的例外
DBMS_OUTPUT.PUT_LINE('Nosuchdepartmentid.');
END;
一個簡單的存儲過程案例:
CREATEPROCEDUREquery_emp(p_idINemployees.employee_id%TYPE,
p_nameOUTemployees.last_name%TYPE,
p_salaryOUTemployees.salary%TYPE,
p_commOUTemployees.commission_pct%TYPE)
AUTHIDCURRENT_USERIS
BEGIN
SELECTlast_name,salary,commission_pct
INTOp_name,p_salary,p_comm
FROMemployees
WHEREemployee_id=p_id;
ENDquery_emp;
『肆』 .sql文件中怎麼聲明變數請詳細說一下。
聲明變數:
declare @變數名 變數類型
如:
declare @datetime datetime
設置變數值:
set @變數名 = 值
設置變數為當前時間:
set @變數名 = getdate()
『伍』 sql語言有什麼用途
SQL是Structured Query Language(結構化查詢語言)的縮寫,它是目前使用最廣泛的資料庫語言,SQL是由IBM發展起來的,後來被許多資料庫軟體公司接受而成為了業內的一個標准。 SQL是一種結構化資料庫查詢語言,其發音為「sequel」或「S-Q-L」。盡管MICROSOFT以其特有的方式加入了所有權聲明,但它在大多資料庫應用中近乎成為一種標准。簡言之,它是一種使用你選擇的標准從資料庫記錄中選擇某些記錄的方法。 就象SQL的名字一樣,我們可以通過容易理解的查詢語言,來和資料庫打交道,從資料庫中得到我們想要的數據。對於SQL語言,有兩個組成部分: DML(data manipulation language):它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來對資料庫里的數據進行操作的語言。 DDL(data definition language):DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定義或改變表(TABLE)的結構,數據類型,表之間的鏈接和約束等初始化工作上,他們大多在建立表時使用。 了解這兩個部分的不同對於你今後使用時有很多方便,因為許多SQL語言中的約束也是根據這個分類來劃分的,比如:你在ORACLE中建立資料庫鏈,那麼只有DML類語言能對鏈接的資料庫進行操作。 SQL作為一個ANSI標准,一直在不斷改進,現在最新的標準是SQL99。ORACLE不但對標準的SQL完全兼容,而且有自己更為方便的增強SQL,所以這里介紹的主要是ORACLE8中使用的SQL。
『陸』 sql聲明變數
dj和bw都得先聲明,後使用。
其實你sql里不用加變數,直接把 x1,x2,y1,y2 用上就行了,不用那麼麻煩加到變數里。
可以直接 用 and 東經>=x1 and 東經<=x2 and ........
如果非要使用變數。得在 sb.Append("select 工單流水號,東經,北緯,申告內容,工單提交時間,工單類型 from db... 前面再加上生命變數的語句。
如果是sqlserver 就是 sb.append("declare @dj1 float,@dj2 float ,@bw1 float,@bw2 float");
然後後面查詢條件才能用到 @dj1 @dj2