select編程
Ⅰ 如何在select語句裡面對SQL的結果集進行處理用model函數就夠了
Model語句是Oracle 10g的新功能之一。下面主要通過一些簡單的例子來幫助大家理解Model語句的用法。
以下基於Oracle11.2.0.4測試。
model語句是Oracle10g的新功能,可以在select語句裡面像其他編程語言操作數組一樣,對SQL的結果集進行處理。執行順序是位於Having之後。
select的解析執行順序
model的好處
Oracle 9i為止,需要使用各種計算分析函數,union all等,以及藉助其他開發語言(C#及Java等)進行復雜計算統計合並等。使用Model之後,這些都可以在SQL裡面進行了。
model典型使用場景:
1、例子1:
結果:
說明:
根據下面語句model dimension by (soeji) measures(ArrValue) soeji作為索引對數組ArrValue進行操作,rules(ArrValue[1] = 'Hello World')就是說用Hello World覆蓋ArrValue[1]裡面的值。
2、例子2
執行結果:
rules的預設行為是存在就更新,不存在則追加,因此,ArrValue[1] = 'Hello World'是更新一條,ArrValue[2] = 'Hello Model'insert一條。
3、例子3:
model語句裡面,索引可以是不連續的。
4、例子4
使用model return updated rows的話,被rules更新或者插入的行才顯示,沒有更新過的行不再作為SQL的結果。
篇幅有限,這里主要簡單介紹一下model的用法,大家感興趣的話建議做一下相關實驗深入了解下。
後面會分享更多devops和DBA方面的內容,感興趣的朋友可以關注一下~
Ⅱ 網路編程中select函數如何接受一個accept事件
#include <winsock.h>
#include <stdio.h>
#define PORT 5150 //埠
#define MSGSIZE 1024 //信息大小
#pragma comment(lib, "ws2_32.lib")
int g_iTotalConn = 0; //連接數量
SOCKET g_CliSocketArr[FD_SETSIZE]; //套接字數組
DWORD WINAPI WorkerThread(LPVOID lpParameter);//線程函數
int main()
{
WSADATA wsaData;
SOCKET sListen, sClient;
SOCKADDR_IN local, client;
int iaddrSize = sizeof(SOCKADDR_IN);
DWORD dwThreadId;
// Initialize Windows socket library
//裝載套接字型檔
WSAStartup(0x0202, &wsaData);
// Create listening socket
//創建套接字
sListen = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
// Bind
//綁定
local.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
local.sin_family = AF_INET;
local.sin_port = htons(PORT);
bind(sListen, (struct sockaddr *)&local, sizeof(SOCKADDR_IN));
// Listen
//監聽
listen(sListen, 3);
// Create worker thread
//創建線程
CreateThread(NULL, 0, WorkerThread, NULL, 0, &dwThreadId);
while (TRUE)
{
// Accept a connection
//接受一個連接,返回的是客戶套的套接字
sClient = accept(sListen, (struct sockaddr *)&client, &iaddrSize);
//這里client的SOCKADDR_IN client 中可以取出IP
printf("Accepted client:%s:%d ", inet_ntoa(client.sin_addr), ntohs(client.sin_port));
// Add socket to g_CliSocketArr
//把客戶端套接字放入數組中
g_CliSocketArr[g_iTotalConn++] = sClient;
}
return 0;
}
DWORD WINAPI WorkerThread(LPVOID lpParam)//線程
{
int i;
fd_set fdread;//結構
int ret;
struct timeval tv = {1, 0};//超時時間 SELECT模型中用到的這里是1秒
char szMessage[MSGSIZE];//信息數組,事實上就是個緩沖區
while (TRUE)
{
FD_ZERO(&fdread);//清空fd_set結構
for (i = 0; i < g_iTotalConn; i++)
{
FD_SET(g_CliSocketArr[i], &fdread);//把客戶套接字放到SELECT要求的數組中
}
//**************************************
// We only care read event
//只關心讀的情況
ret = select(0, &fdread, NULL, NULL, &tv);
if (ret == 0)
{
// Time expired 超時
continue;
}
//如果SELECT返回不是0
for (i = 0; i < g_iTotalConn; i++)
{
if (FD_ISSET(g_CliSocketArr[i], &fdread))
{
// A read event happened on g_CliSocketArr[i]
//一個可讀發生在這個套接字上
ret = recv(g_CliSocketArr[i], szMessage, MSGSIZE, 0);
//把它讀出到緩沖區
if (ret == 0 || (ret == SOCKET_ERROR && WSAGetLastError() == WSAECONNRESET))
{
// Client socket closed
//客戶端關閉
printf("Client socket %d closed. ", g_CliSocketArr[i]);
closesocket(g_CliSocketArr[i]);//關閉這個套接字
if (i < g_iTotalConn - 1)
{
//將數組中最後一個套接字挪到當前的位置上
g_CliSocketArr[i--] = g_CliSocketArr[--g_iTotalConn];
}
}
else
{
// We received a message from client
//如果以上沒發生,那麼就接收到一個客戶端的信息
szMessage[ret] = '