[với [đệ quy]with_query[, ...]] kèo bóng đá pháp [chỉ]Table_Name[ *] [[As]bí danh] BỘCột_name=Biểu thức| Mặc định | (Cột_name[, ...]) = (Biểu thức| Mặc định [, ...]) | (Cột_name[, ...]) = (Sub-Select) [, ...] [ TỪfrom_item[, ...]] [ Ở ĐÂUđiều kiện| Nơi hiện tại củacon trỏ_name] [Trả lại * |output_expression[[As]output_name] [, ...]]
kèo bóng đá phápThay đổi các giá trị của các cột được chỉ định trong tất cả các hàng thỏa mãn điều kiện. Chỉ các cột được sửa đổi cần được đề kèo bóng đá pháp trongsetmệnh đề; kèo bóng đá pháp cột không được sửa đổi rõ ràng giữ lại kèo bóng đá pháp giá trị trước đó của chúng.
Có hai cách để sửa đổi bảng bằng cách sử dụng thông tin có trong kèo bóng đá pháp bảng khác trong cơ sở dữ liệu: Sử dụng kèo bóng đá pháp lựa chọn phụ hoặc chỉ định kèo bóng đá pháp bảng bổ sung trongtừ11809_11894
Tùy chọnTrở vềmệnh đề gây rakèo bóng đá pháp11993_12149từ, có thể được tính toán. kèo bóng đá pháp giá trị mới (Post Update) của kèo bóng đá pháp cột của bảng được sử dụng. Cú pháp củaTrở vềDanh sách giống hệt với danh sách đầu ra của12378_12386.
Bạn phải cókèo bóng đá phápĐặc quyền trên bảng hoặc ít nhất là trên (các) cột được liệt kê để được kèo bóng đá pháp. Bạn cũng phải cóChọnĐặc quyền trên bất kỳ cột nào có giá trị được đọc trongBiểu thứchoặcđiều kiện.
Thevới12946_13039kèo bóng đá phápTruy vấn. Nhìn thấyPhần 7.813123_13130ChọnĐể biết chi tiết.
Tên (tùy chọn Lược đồ theo trình độ) của bảng để kèo bóng đá pháp. Nếu nhưchỉđược chỉ định trước tên bảng, các hàng khớp chỉ được kèo bóng đá pháp trong bảng được đặt tên. Nếu nhưchỉKhông được chỉ định, các hàng khớp cũng được kèo bóng đá pháp trong bất kỳ bảng nào được kế thừa từ bảng được đặt tên. Tùy chọn,*Có thể được chỉ định sau tên bảng để chỉ ra rõ ràng rằng kèo bóng đá pháp bảng hậu duệ được bao gồm.
Một tên thay thế cho bảng đích. Khi một bí danh được cung cấp, nó hoàn toàn ẩn tên thực tế của bảng. Ví dụ, đã chokèo bóng đá pháp foo as f, phần còn lại củakèo bóng đá phápCâu lệnh phải gọi bảng này làfkhôngfoo.
Tên của một cột trong bảng được đặt tên bởiTable_Name. Tên cột có thể đủ điều kiện với một tên trường con hoặc chỉ số mảng, nếu cần. Không bao gồm tên của bảng trong đặc điểm kỹ thuật của cột đích - ví dụ:kèo bóng đá pháp bảng_name set table_name.col = 1không hợp lệ.
Một biểu thức để gán cho cột. Biểu thức có thể sử dụng kèo bóng đá pháp giá trị cũ của kèo bóng đá pháp cột này và kèo bóng đá pháp cột khác trong bảng.
Đặt cột thành giá trị mặc định của nó (sẽ là NULL nếu không có biểu thức mặc định cụ thể nào được gán cho nó).
AChọnTrình tải phụ tạo ra nhiều cột đầu ra như được liệt kê trong danh sách cột dấu ngoặc đơn trước nó. Trình độ phụ phải mang lại không quá một hàng khi được thực hiện. Nếu nó mang lại một hàng, các giá trị cột của nó được gán cho các cột đích; Nếu nó mang lại không có hàng, các giá trị null được gán cho các cột đích. Trình độ phụ có thể tham khảo các giá trị cũ của hàng hiện tại của bảng được kèo bóng đá pháp.
Biểu thức bảng cho phép kèo bóng đá pháp cột từ kèo bóng đá pháp bảng khác xuất hiện trongWHEREBiểu thức điều kiện và kèo bóng đá pháp. Điều này sử dụng cùng một cú pháp vớitừ mệnh đềcủa AChọnTuyên bố; Ví dụ, một bí danh cho tên bảng có thể được chỉ định. Không lặp lại bảng đích dưới dạngfrom_itemTrừ khi bạn có ý định tự tham gia (trong trường hợp đó nó phải xuất hiện với bí danh trongfrom_item).
Một biểu thức trả về giá trị của loạiBoolean. Chỉ kèo bóng đá pháp hàng mà biểu thức này trả vềTRUEsẽ được kèo bóng đá pháp.
Tên của con trỏ sẽ sử dụng trong Atrong đó hiện tại củaĐiều kiện. Hàng được kèo bóng đá pháp là một hàng gần đây nhất được lấy từ con trỏ này. Con trỏ phải là một truy vấn không nhóm trên16510_16518Bảng mục tiêu. Lưu ý rằngtrong đó hiện tại củaKhông thể được chỉ định cùng với điều kiện Boolean. Nhìn thấykhai báoĐể biết thêm thông tin về việc sử dụng con trỏ vớitrong đó hiện tại của.
Một biểu thức được tính toán và trả về bởikèo bóng đá phápLệnh sau mỗi hàng được kèo bóng đá pháp. Biểu thức có thể sử dụng bất kỳ tên cột nào của bảng được đặt tên bởiTable_Name17074_17099từ. Viết*Để trả về tất cả kèo bóng đá pháp cột.
tên sẽ sử dụng cho cột được trả về.
Khi hoàn thành thành công, mộtkèo bóng đá phápLệnh trả về thẻ lệnh của biểu mẫu
kèo bóng đá phápĐếm
TheĐếmlà số lượng hàng được kèo bóng đá pháp, bao gồm cả các hàng phù hợp có giá trị không thay đổi. Lưu ý rằng số có thể nhỏ hơn số lượng hàng khớp vớiđiều kiệnKhi kèo bóng đá pháp bị đàn áp bởiTrước khi kèo bóng đá phápTrigger. Nếu nhưĐếmlà 0, không có hàng nào được kèo bóng đá pháp bởi truy vấn (đây không được coi là lỗi).
Nếukèo bóng đá phápLệnh chứa ATrở vềmệnh đề, kết quả sẽ tương tự như của AChọnCâu lệnh chứa kèo bóng đá pháp cột và giá trị được xác định trongTrở vềDanh sách, được tính toán trên (s) được kèo bóng đá pháp bởi lệnh.
Khi AtừĐiều khoản có mặt, về cơ bản xảy ra là bảng đích được nối với các bảng được đề kèo bóng đá pháp trongfrom_itemDanh sách và mỗi hàng đầu ra của tham gia đại diện cho hoạt động kèo bóng đá pháp cho bảng đích. Khi sử dụng18751_18757Bạn nên đảm bảo rằng tham gia tạo ra nhiều nhất một hàng đầu ra cho mỗi hàng được sửa đổi. Nói cách khác, một hàng mục tiêu không nên nối với nhiều hơn một hàng từ (các) bảng khác. Nếu có, thì chỉ có một trong các hàng tham gia sẽ được sử dụng để kèo bóng đá pháp hàng mục tiêu, nhưng cái nào sẽ được sử dụng không thể dự đoán được.
Vì sự không xác định này, việc tham chiếu kèo bóng đá pháp bảng khác chỉ trong kèo bóng đá pháp lựa chọn phụ là an toàn hơn, mặc dù thường khó đọc và chậm hơn so với sử dụng tham gia.
Thay đổi từkịchđếnDramaticTrong cộtKindcủa bảngPhim:
19540_19598
Điều chỉnh kèo bóng đá pháp mục nhập nhiệt độ và đặt lại lượng mưa theo giá trị mặc định của nó trong một hàng của bảngthời tiết:
kèo bóng đá pháp bộ thời tiết đặt TEMP_LO = TEMP_LO+1, TEMP_HI = TET Nơi City = 'San Francisco' và Date = '2003-07-03';
Thực hiện cùng một thao tác và trả về các mục được kèo bóng đá pháp:
20004_20173
Sử dụng cú pháp danh sách cột thay thế để thực hiện cùng một bản kèo bóng đá pháp:
kèo bóng đá pháp bộ thời tiết (temp_lo, temp_hi, prcp) = (temp_lo+1, temp_lo+15, mặc định) Nơi City = 'San Francisco' và Date = '2003-07-03';
Tăng số lượng doanh số của nhân viên bán hàng quản lý tài khoản cho Tập đoàn ACME, sử dụngtừCú pháp mệnh đề:
kèo bóng đá pháp nhân viên đặt Sales_count = sales_count + 1 từ tài khoản Nơi tài khoản.name = 'Acme Corporation' Và nhân viên.id = tài khoản.sales_person;
Thực hiện cùng một thao tác, sử dụng một lựa chọn phụ trongWHEREmệnh đề:
kèo bóng đá pháp nhân viên đặt sales_count = sales_count + 1 trong đó id = .
kèo bóng đá pháp tên liên lạc trong bảng tài khoản để khớp với nhân viên bán hàng được chỉ định:
kèo bóng đá pháp bộ tài khoản (contact_first_name, contact_last_name) = (Chọn First_Name, Last_Name từ nhân viên bán hàng WHERE SalesMeN.id = access.sales_id);
Một kết quả tương tự có thể được thực hiện bằng một lần tham gia:
kèo bóng đá pháp tài khoản đặt contact_first_name = first_name, contact_last_name = last_name Từ nhân viên bán hàng nơi nhân viên bán hàng.id = tài khoản.sales_id;
Tuy nhiên, truy vấn thứ hai có thể cho kết quả không mong muốn nếuNhân viên bán hàng.id21681_21783idphù hợp. Ngoài ra, nếu không có sự phù hợp cho một cụ thểtài khoản.sales_idMục nhập, truy vấn đầu tiên sẽ đặt các trường tên tương ứng thành NULL, trong khi truy vấn thứ hai sẽ không kèo bóng đá pháp hàng đó.
kèo bóng đá pháp số liệu thống kê trong bảng tóm tắt để phù hợp với dữ liệu hiện tại:
kèo bóng đá pháp Tóm tắt S Set (SUM_X, SUM_Y, AVG_X, AVG_Y) = . Trong đó D.group_id = s.group_id);
Cố gắng chèn một mặt hàng chứng khoán mới cùng với số lượng cổ phiếu. Nếu mặt hàng đã tồn tại, thay vào đó, hãy kèo bóng đá pháp số lượng cổ phiếu của mặt hàng hiện có. Để làm điều này mà không thất bại toàn bộ giao dịch, hãy sử dụng các điểm lưu:
22575_22920
Thay đổiKindCột của bảngPhimTrong hàng mà con trỏc_filmsHiện đang được định vị:
23148_23210
Lệnh này phù hợp vớiSQLtiêu chuẩn, ngoại trừtừvàTrở vềmệnh đề làPostgreSQLTiện ích mở rộng, cũng như khả năng sử dụngvớivớikèo bóng đá pháp.
Một số hệ thống cơ sở dữ liệu khác cung cấp Atừtùy chọn trong đó bảng đích được cho là được liệt kê lại trongtừ. Đó không phải là cáchPostgreSQLGiải thíchtừ. Hãy cẩn thận khi chuyển kèo bóng đá pháp ứng dụng sử dụng tiện ích mở rộng này.
Theo tiêu chuẩn, giá trị nguồn cho danh sách phụ của tên cột có thể là bất kỳ biểu thức có giá trị hàng nào mang lại số lượng cột chính xác.PostgreSQLChỉ cho phép giá trị nguồn là danh sách dấu ngoặc đơn của kèo bóng đá pháp biểu thức hoặc phụ-Chọn. Giá trị được kèo bóng đá pháp của một cột cá nhân có thể được chỉ định làMặc địnhTrong trường hợp danh sách biểu hiện, nhưng không phải bên trong phụ-Chọn.