A. access vba 一個sub多次使用sql
1)sql2 = "select last(成本單價) from RM_櫥櫃分廠材料成本2015 where 材料類別 = '" & Combo0.Value & "'"
data.Open sql1, CurrentProject.Connection, adOpenKeyset, adLockOptimistic
這里也是sql1么?似乎應改為sql2吧
2)關了sql1重開sql2沒什麼不可以的,那是在釋放記錄集對象所佔用的內存,對於在低性能電腦上運行程序是很有好處的。
3)如果是多個記錄的記錄集,可以使用do……loop循環之類的方法移動指針而不必重開記錄集,但你上面這兩個記錄集都是匯總查詢單記錄的,用不到的。以do……loop循環為例:
with data
.movefirst
do until .eof
Text25 = .Fields(0)
.movenext
loop
end with
B. sql中,取時間最近的一條記錄
selecttest.sub_dh,test.date,test.Gname
fromtest,(SELECTSub_dhasdh,MAX(Date)asdateFROMdbo.testGROUPBYSUB_DH)a
wheretest.Sub_dh=a.dh
andtest.date=a.date
看你寫的SQL,GROUPBY的用法還是沒有太理解
C. 在SQL語句中,定義了@mth,如何表示前一個月,是sub(@mth-1)嗎
@mth是什麼??
select dateadd(month,-1,getdate())
-----------------------------------------
@mth就是你傳進來的時間的話
那就是:
select dateadd(month,-1,@mth)
D. 如何用SQL語句實現子分類中的不同項目自動添加數字編號
有個問題:你為什麼強調「同一個ID下」?
如果跟是不是在「同一個ID下」沒有半毛錢關系,你的問題可以簡化成:查出來的每條記錄裡面SUB_NAME是存在的,SUB_ID是空著的,現在要把相同的SUB_NAME賦予相同的SUB_ID。
如果我的理解是正確的話,那麼:
1、你另外建一張表,比如叫SUB_ID_NAME_COMP,然後一個欄位是SUB_ID,另一個是SUB_NAME,然後你在這張表裡面把對應關系整理好;
2、寫下面這個腳本搞起:
select'updateAseta.sub1_id='||
(selectx.sub_id
fromSUB_ID_NAME_COMPx
wherex.sub_name=a.sub1_name)||',a.sub2_id='||
(selectx.sub_id
fromSUB_ID_NAME_COMPx
wherex.sub_name=a.sub2_name)||'wherea.sub1_name='||
A.SUB1_NAME||'anda.sub2_name='||A.sub2_name||';'
fromA;
其它,如果跟「同一個ID」有關系的話,上面的腳本在寫的時候再把ID相關的信息帶進去做好控制。
E. 怎麼在SQL中設置外鍵
sql server中建立外鍵約束有3中方式:enterprise manager中,tables,design table,設置table的properties,可以建立constraint, reference key;enterprise manager中,diagrams, new diagrams,建立兩個表的關系;直接用transact sql語句。
1、三個方法都需要先建立數據表。
1)創建表author :
create table [dbo].[author] (
[id] [bigint] not null ,
[authorname] [char] (10) null ,
[address] [char] (480) null ,
[introction] [ntext] null
)
2)創建表mybbs:
reate table [dbo].[mybbs] (
[id] [bigint] identity (1, 1) not null ,
[authorid] [bigint] not null ,
[title] [char] (40) null ,
[date_of_created] [datetime] null ,
[abstract] [char] (480) null ,
[content] [ntext] null
)
2、設置表mybbs中的authorid為外鍵,參照author表的id欄位,直接使用transact sql語句,過程如下:
1)增加表mybbs(authorid)的外鍵約束fk_mybbs_author,表mybbs中的authorid受表author中的主鍵id約束:
begin transaction
alter table dbo.mybbs add constraint fk_mybbs_author
foreign key (authorid)
references dbo.author([id]) on update cascade on delete cascade
2)刪除外鍵約束fk_mybbs_author:
--alter table dbo.mybbs drop constraint fk_mybbs_author
--rollback
commit transaction
上面on update cascade,on delete cascade兩個選項,指明以後author表的id欄位有delete,update操作時,mybbs表中的id也會被級聯刪除或更新。如果沒有選中,是不可以對author表中已被mybbs表關聯的id進行update或者delete操作的。
拓展資料:
SQL的主鍵和外鍵的作用:
1、插入非空值時,如果主鍵表中沒有這個值,則不能插入。
2、更新時,不能改為主鍵表中沒有的值。
3、刪除主鍵表記錄時,你可以在建外鍵時選定外鍵記錄一起級聯刪除還是拒絕刪除。
4、更新主鍵記錄時,同樣有級聯更新和拒絕執行的選擇。
簡而言之,SQL的主鍵和外鍵就是起約束作用。
F. select 1 from sql語句中的1代表什麼意思
每個「1」代表有1行記錄,同時選用數字1還因為它所佔用的內存空間最小。
一個很不錯的SQL語句寫法,它通常用於子查詢。
可以減少系統開銷,提高運行效率。
因為這樣子寫的SQL語句,資料庫引擎就不會去檢索數據表裡一條條具體的記錄和每條記錄里一個個具體的欄位值並將它們放到內存里。
根據查詢到有多少行存在就輸出多少個「1」。
用數字0的效果也一樣。
在不需要知道具體的記錄值是什麼的情況下這種寫法無疑更加可取。
G. SQL server2000 中如何將,表「sub1」,將列名為「ID」中的「0402010B00」,按照列名為「記錄時間」查找
SQLSERVER支持TOP N,按照時間倒序排,取第一個
select top 1 * from sub1 where [id] = '0402010B00' order by 記錄時間 desc
H. sql中sequence的用法
insert into PRODUCT (你建的序列.NEXTVAL,PRD_DESCRIPTION) values (id,description)
在每次插入數據的時候,id都會按你建的序列的增量自動增加。
sequence就是所謂的序列號,每次取的時候它會自動增加,一般用在需要按序列號排序的地方。
1、 create sequence
你首先要有create sequence或者create any sequence許可權,
create sequence emp_sequence
INCREMENT BY 1 -- 每次加幾個
START WITH 1 -- 從1開始計數
NOMAXVALUE -- 不設置最大值
NOCYCLE -- 一直累加,不循環
CACHE 10;
一旦定義了emp_sequence,你就可以用CURRVAL,NEXTVAL
CURRVAL=返回sequence的當前值
NEXTVAL=增加sequence的值,然後返回sequence值
比如:
emp_sequence.CURRVAL
emp_sequence.NEXTVAL
可以使用sequence的地方:
- 不包含子查詢、snapshot、VIEW的 SELECT 語句
- INSERT語句的子查詢中
- NSERT語句的VALUES中
- UPDATE 的 SET中
可以看如下例子:
INSERT INTO emp VALUES
(empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);
SELECT empseq.currval FROM DUAL;
但是要注意的是:
- 第一次NEXTVAL返回的是初始值;隨後的NEXTVAL會自動增加你定義的INCREMENT BY值,
然後返回增加後的值。CURRVAL 總是返回當前sequence的值,但是在第一次NEXTVAL
初始化之後才能使用CURRVAL,否則會出錯。一次NEXTVAL會增加一次sequence的值,
所以如果你在同一個語句裡面使用多個NEXTVAL,其值就是不一樣的。明白?
- 如果指定CACHE值,oracle就可以預先在內存裡面放置一些sequence,這樣存取的快
些。
cache裡面的取完後,oracle自動再取一組到cache。 使用cache或許會跳號, 比如
資料庫突然不正常down掉(shutdown abort),cache中的sequence就會丟失. 所以可
以在create sequence的時候用nocache防止這種情況。
2、 Alter sequence
你或者是該sequence的owner,或者有ALTER ANY sequence許可權才能改動sequence。 可
以alter除start值之外的所有sequence參數。如果想要改變start值,必須drop sequence
再re-create。例子:
ALTER sequence emp_sequence
INCREMENT BY 10
MAXVALUE 10000
CYCLE -- 到10000後從頭開始
NOCACHE;
影響sequence的初始化參數:
sequence_CACHE_ENTRIES =
設置能同時被cache的sequence數目。
可以很簡單的Drop sequence
DROP sequence order_seq;
sequence的用法:
create seqence sequence_name
[start with n1] ----------------->n1到n5都是整數;start with 生成的第一個n1值
[increment by n2] -----------------> increment by n2 遞增量,可以為正整數或負整數,指明每一次增加多少
[maxvalue n3|no maxvalue]----------------->maxvalue最大值,no maxvalue用於指定序列沒有上限
[minvalue n4|no minvalue]----------------->minvalue 最小值,no minvalue,沒有指定最小下限
[cache n5|no cache] ----------------->cache 用高速緩存中可以預分配的序列號個數,默認是20。 如果緩存中的序列號沒有用完就關閉資料庫等其它原因.
使用 sequence
CURRVAL 和 NEXTVAL 能夠在以下情況使用:insert的values字句、select中的select列表、update中的set字句
CURRVAL 和 NEXTVAL 不能夠在以下情況使用:子查詢、視圖和實體化視圖的查詢、帶distinct的select語句、帶 group by和order by的select語句、帶union或intersect或minus的select語句、select中的where字句、create table與alter table中的default值、check約束條件。
刪除sequence
drop sequence seq_a;當刪除sequence後,對應它的同義詞會被保留,但是引用時會報錯。
oracle rac環境中的sequence
oracle為了在rac環境下為了sequence的一致性,使用了三種鎖:row cache lock、SQ鎖、SV鎖。
row cache lock的目的是在sequence指定nocache的情況下調用sequence.nextval過程中保證序列的順序性;
SQ鎖是應用於指定了cache+noorder的情況下調用sequence.nextval過程中。
SV 鎖(dfs lock handel) 是調用sequence.nextval期間擁有的鎖。前提是創建sequence時指定了cache 和order屬性 (cache+order)。order參數的目的是為了在RAC上節點之間生成sequence的順序得到保障。
創建sequence賦予的cache值較小時,有enq:sq-contention等待增加的趨勢。
cache的預設值是20.因此創建並發訪問多的sequence時,cacheh值應取大一些。否則會發生enq:sq-contention等待事件。
rac上創建sequence時,如果指定了cache大小而賦予noorder屬性,則各節點將會把不同范圍的sequence值cache到內 存上。若兩個節點之間都必須通過依次遞增方式使用sequence,必須賦予如下的order屬性(一般不需要這樣做)」sql> create sequence seq_b cache 100 order」。
如果是已賦予了cache+order屬性的sequence,oracle使用SV鎖進行同步。SV鎖爭用問題發生時的解決方法與sq鎖 的情況相同,就是將cache 值進行適當調整。
在RAC多節點環境下,Sequence的Cache屬性對性能的影響很大。應該盡量賦予cache+noorder屬性,並要給予足夠的 cache值。如果需要保障順序,必須賦予cache+order屬性。但這時為了保障順序,實例之間需要不斷的交換數據。因此性能稍差。
(8)sql中sub1的用法擴展閱讀:
seqence的作用:
sequence號是資料庫系統按照一定規則自增的數字序列,因為自增所以不會重復。目前就我所了解的sequence的作用主要有兩個方面。
一:作為代理主鍵,唯一識別;
二:用於記錄資料庫中最新動作的語句,只要語句有動作(insert/delete等),sequence號都會隨著更新,所以我們可以根據sequence號來select出更新的語句。
I. 資料庫連接能否使用sub函數
function OpenConn(DataStr) '資料庫連接
'dim conn,db
'dim connstr
db=""&DataStr&".accdb" '資料庫文件位置
connstr="Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & Server.MapPath(""&db&"")
on error resume next
set OpenConn=server.createobject("ADODB.CONNECTION")
if err then
err.clear
Response.Write("伺服器維護中,請稍後再試!")
else
OpenConn.open connstr
end if
end function
這里是調用 的
set rs=server.createobject("adodb.recordset")
sql="select * from admin where username='"&username&"'"
rs.open sql,OpenConn("data/data"),3,3
J. SQL中如何用一條語句刪除一個學生(學生編號為040101)的信息以及選課信息命令代碼是什麼
假如你的 外鍵關系,
是 DELETE CASCADE 方式 的,
那麼, 刪除 主表的數據的時候, 資料庫 會自動 刪除掉 子表裡面的數據
不需要額外寫任何代碼.
1> -- 創建外鍵(使用 ON DELETE CASCADE 選項,刪除主表的時候,同時刪除子表)
2> ALTER TABLE test_sub
3> ADD CONSTRAINT main_id_cons
4> FOREIGN KEY (main_id) REFERENCES test_main ON DELETE CASCADE;
5>
6> -- 測試刪除主表數據. 將成功地執行.
7> DELETE
8> TEST_MAIN
9> WHERE
10> ID = 1;
11>
12> -- 測試檢索子表,應該只有一條 main_id = 2 的數據.
13> SELECT
14> *
15> FROM
16> test_sub;
17>
18> go
(1 行受影響)
id main_id value
----------- ----------- ----------
2 2 TWOTWO
(1 行受影響)