亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? insert.c

?? 數據庫系統實現
?? C
字號:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <io.h>
#include <fcntl.h>
#include <time.h >
#include "linear_hash.h"

extern BUCKET_BUF 		bucket;
extern DATA_BUF		data;
extern NTH_BLOCK_BUF	nth_blk_relation;
extern HASH_INFO 		hash_info;

extern long			DATA_CUR;//記錄最后最后讀入的數據塊號
extern long			NTH_BLK_CUR;//記錄最后讀入的對應信息塊號
extern long			SEARCH_CUR;

extern BUCKET_BUF		buk_buf[BUCKET_BUFFER_SIZE];
extern BUCKET_BUF		buk_over_buf[BUCKET_BUFFER_SIZE];
extern DATA_BUF			dat_buf[DATA_BUFFER_SIZE];
extern NTH_BLOCK_BUF	nth_blk_buf[NTH_BLOCK_BUFFER_SIZE];
void insert_idx(char *filename)
{
	long fd = 0;
	long dlength = 0;
	long j = 0;
	long data_volume = 0;
	long i = 0;
	long p = 0;
	long flag = 0;
	
	fd = open("all200000.dat", O_RDWR);
	dlength = filelength(fd)/BLOCK_SIZE;
	close(fd);
	
	insert_to_data_file(filename);
	
	while(dlength != -1)
	{
		j = 0;
		data_volume = 0;
		for(i = 0; i < DATA_BUFFER_SIZE; i++)
		{
			dat_buf[i].from_blk_no = -1;
			for(p = 0; p < LONG_IN_BLOCK; p++)
			{
				dat_buf[i].key[p] = -1;
			}
		}
		while ( j < DATA_BUFFER_SIZE )//讀入需要加入的數據塊
		{
			if( dat_buf[j].from_blk_no == -1 )
			{
				flag = read_dat("all200000.dat", dlength); 
				if(flag != 0)
				{
				dat_buf[j] = data;
				data_volume += flag;
				dlength++;
				}
				else
				{
					dlength = -1;
					break;
				}
			}
			j++;
		}
		scan_data(data_volume);
	}
}

void insert_to_data_file(char *filename)
{
	long fd = 0;
	long dlength = 0;
	long ilength = 0;
	long flag = 0;
	long i = 0;
	long j = 0;
	FILE *fp = NULL;
	fd = open("all200000.dat", O_RDWR);
	dlength = filelength(fd)/BLOCK_SIZE;
	close(fd);
	fd = open(filename, O_RDWR);
	ilength = filelength(fd)/BLOCK_SIZE;
	close(fd);
	
	fp = fopen("all200000.dat", "rb+");
	for( i = 0; i < ilength; i++)
		get_blk(fp);
	fclose(fp);
	
	for(i = 0; i < ilength; i++)
	{
		for( j = 0; j < DATA_BUFFER_SIZE; j++)
			dat_buf[j].from_blk_no = -1;
		
		for( j = 0; j < DATA_BUFFER_SIZE; j++)
		{
			flag = read_dat(filename, i);
			if(flag != 0)
			{
				dat_buf[j] = data;
				i++;
			}
			else
				break;
		}
		for( j = 0; j < DATA_BUFFER_SIZE; j++)
		{
			if(dat_buf[j].from_blk_no != -1)
			{
				data = dat_buf[j];
				write_dat("all200000.dat", dlength);
				dlength++;
			}
		}
	}
}

void insert_single(long key)
{
	long key_blk_no = -1;
	long key_offset = -1;
	long found = 1;
	long flag = 0;
	long add_in = 0;
	long old_hash_info_hkey_i = 0;
	long old_hash_info_bucket_no = 0;
	long hkey = 0;
	long power = 0;
	long change_in = 0;
	long i = 0;
	long j = 0;
	FILE *fp = NULL;
	if(key == -1)
		return;

	while(found)
	{
		flag = read_dat("all200000.dat", j);
		if(flag != 0)
		{
			for( i = 0; i < LONG_IN_BLOCK; i++)
			{
				if(data.key[i] == -1 || data.key[i] == key)
				{
					data.key[i] = key;
					key_blk_no = j;
					key_offset = sizeof(long) * i;
					write_dat("all200000.dat", data.from_blk_no);
					found = 0;
					break;
				}
			}
			j++;
		}
		else
		{
			fp = fopen("all200000.dat", "rb+");
			get_blk(fp);
			fclose(fp);
			read_dat("all200000.dat", j + 1 );
			data.key[0] = key;
			write_dat("all200000.dat", data.from_blk_no);
			key_blk_no = j + 1;
			key_offset = 0;
			found = 0;
			break;
		}
	}
	
	power = pow(2, hash_info.hkey_i - 1);
	
	if(key != -1)
	{
		hkey = add_in_which(key, hash_info.hkey_i);
		if(hkey < hash_info.bucket_no)
			add_in = hkey;
		else
			add_in = hkey - power;
	}
	old_hash_info_hkey_i = hash_info.hkey_i;
	old_hash_info_bucket_no = hash_info.bucket_no;
	renew_hash_info(1);
	add_hash_table_bucket("hash_table.idx", old_hash_info_bucket_no);
	
	if(old_hash_info_hkey_i == hash_info.hkey_i && old_hash_info_bucket_no == hash_info.bucket_no)
	{
		insert_single_read_nth_blk(add_in, key, key_blk_no, key_offset, 1);
	}
	
	if(old_hash_info_hkey_i == hash_info.hkey_i && old_hash_info_bucket_no != hash_info.bucket_no)
	{
		change_in = old_hash_info_bucket_no - power;
		insert_single_read_nth_blk(change_in, key, key_blk_no, key_offset, 2); 
	}
	
	if(old_hash_info_hkey_i != hash_info.hkey_i && old_hash_info_bucket_no != hash_info.bucket_no)
	{
		change_in = old_hash_info_bucket_no - power * 2;
		insert_single_read_nth_blk(change_in, key, key_blk_no, key_offset, 2); 
	}
}

void insert_single_read_nth_blk(long fhkey, long key, long blk_no, long offset, long any)
{
	long j = 0;
	long i = 0;
	long flag = 0;
	NTH_BLK_CUR = 0;
	while( j < NTH_BLOCK_BUFFER_SIZE )//讀入對應關系文件塊
	{
		if (nth_blk_buf[j].from_blk_no == -1)
		{
			flag = read_nth_blk("nth_block.dat", NTH_BLK_CUR);
			if(flag == 1)
			{
				nth_blk_buf[j] = nth_blk_relation;
				for( i = 0; i < NTH_BLOCK_IN_BLOCK; i++)
				{
					if(nth_blk_buf[j].nth_blk[i].nth_bucket == fhkey)
					{
						insert_single_scan_in_buf_nth_blk(fhkey, key, blk_no, offset, any);
						goto ZZ;
					}
				}
				NTH_BLK_CUR++;
			}
			else
			{
				break;
			}
		}
		j++;
	}
	ZZ: ;
}

void insert_single_scan_in_buf_nth_blk(long fhkey, long key, long blk_no, long offset, long any)
{
	long i = 0;
	long j = 0;
	long m = 0;
	long n = 0;
	while( m < NTH_BLOCK_BUFFER_SIZE)
	{
		if(nth_blk_buf[m].from_blk_no != -1)
		{
			while( n < NTH_BLOCK_IN_BLOCK)
			{
				if( nth_blk_buf[m].nth_blk[n].nth_bucket == fhkey)
				{
					read_idx("hash_table.idx", nth_blk_buf[m].nth_blk[n].nth_bucket, nth_blk_buf[m].nth_blk[n].blk_no);
					while(j < BUCKET_BUFFER_SIZE)
					{	
						i = 0;
						while(bucket.buk.blk_no != -1)//判斷當前桶的溢出桶個數
						{
							read_idx("hash_table.idx", nth_blk_buf[m].nth_blk[n].nth_bucket, bucket.buk.blk_no);
							i++;
						}
						
						if( (BUCKET_BUFFER_SIZE - j) >= (i + 1))//將桶和溢出桶讀入
						{
							read_idx("hash_table.idx", nth_blk_buf[m].nth_blk[n].nth_bucket, nth_blk_buf[m].nth_blk[n].blk_no);
							buk_buf[j] = bucket;
							j++;
							while(bucket.buk.blk_no != -1)
							{
								read_idx("hash_table.idx", nth_blk_buf[m].nth_blk[n].nth_bucket, bucket.buk.blk_no);
								buk_buf[j] = bucket;
								j++;
							}
							if ( j == BUCKET_BUFFER_SIZE )
							{
								if(any == 1)
								insert_single_data_operate_1(fhkey, key, blk_no, offset);
								if(any == 2)
								insert_single_data_operate_2(fhkey, key, blk_no, offset);
								j = 0;
								break;
							}
							else
								break;
						}
						else
						{
							if(any == 1)
							insert_single_data_operate_1(fhkey, key, blk_no, offset);
							if(any == 2)
							insert_single_data_operate_2(fhkey, key, blk_no, offset);
							j = 0;
							break;
						}
					}
				}
				n++;
			}
		}
		m++;
	}
	if(any == 1)
	insert_single_data_operate_1(fhkey, key, blk_no, offset);
	if(any == 2)
	insert_single_data_operate_2(fhkey, key, blk_no, offset);
	
	for( j = 0; j < NTH_BLOCK_BUFFER_SIZE; j++ )
	{
		nth_blk_buf[j].from_blk_no = -1;
	}
}
void insert_single_data_operate_1(long fhkey, long key, long blk_no, long offset)
{
	long 	m = 0;
	long 	n = 0;
	long 	found = 0;
	long 	fd = 0;
	long 	length = 0;
	long 	i = 0;
	FILE 	*fp =NULL;
	while( m < BUCKET_BUFFER_SIZE )
	{
		if(fhkey == buk_buf[m].nth_bucket)
		{
			found = 0;
			while(fhkey == buk_buf[m].nth_bucket && found == 0)
			{
				n = 0;
				while( n < HASH_SPACE && found == 0)
				{
					if(buk_buf[m].buk.hk_addr[n].hkey == -1)
					{
						buk_buf[m].buk.hk_addr[n].hkey = key;
						buk_buf[m].buk.hk_addr[n].to_rcd.blk_no = blk_no;
						buk_buf[m].buk.hk_addr[n].to_rcd.offset = offset;
						buk_buf[m].buk.rcd_no++;
						bucket = buk_buf[m];
						printf("INSERT OK!\n");
						write_idx("hash_table.idx", bucket.from_blk_no);
						found = 1;
						goto TT;
					}
					n++;
				}
				m++;
			}
			m--;
			if(found == 0)
			{
				fp = fopen("hash_table.idx", "rb+");
				get_blk(fp);
				fclose(fp);
				fd = open("hash_table.idx", O_RDWR);
				length = filelength(fd)/BLOCK_SIZE;
				close(fd);
				buk_buf[m].buk.blk_no = length - 1;
				buk_buf[m].change_flag = 1;
				read_idx("hash_table.idx", buk_buf[m].nth_bucket, length - 1);
				bucket.buk.blk_no = -1;
				bucket.buk.rcd_no = 1;
				bucket.buk.hk_addr[0].hkey = key;
				bucket.buk.hk_addr[0].to_rcd.blk_no = blk_no;
				bucket.buk.hk_addr[0].to_rcd.offset = offset;
				printf("INSERT OK!\n");
				write_idx("hash_table.idx", length - 1);
				bucket = buk_buf[m];
				write_idx("hash_table.idx", bucket.from_blk_no);
			}
		}
		m++;
	}
	TT: ;
	for(i = 0; i < BUCKET_BUFFER_SIZE; i++)
	{
		buk_buf[i].from_blk_no = -1;
		buk_buf[i].change_flag = 0;
	}	
}

void insert_single_data_operate_2(long fhkey, long key, long blk_no, long offset)
{
	long m = 0;
	long n = 0;
	long p = 0;
	long found = 0;
	long i = 0;
	long fd = 0;
	long length = 0;
	FILE *fp = NULL;
	
	fp = fopen("hash_table.idx", "rb+");
	get_blk(fp);
	fclose(fp);
	fd = open("hash_table.idx", O_RDWR);
	length = filelength(fd)/BLOCK_SIZE;
	close(fd);
	read_idx("hash_table.idx", hash_info.bucket_no - 1, length - 1);
	bucket.buk.blk_no = -1;
	bucket.buk.rcd_no = 1;
	bucket.buk.hk_addr[0].hkey = key;
	bucket.buk.hk_addr[0].to_rcd.blk_no = blk_no;
	bucket.buk.hk_addr[0].to_rcd.offset = offset;
	bucket.change_flag = 1;
	
	while( m < BUCKET_BUFFER_SIZE )
	{
		if(fhkey == buk_buf[m].nth_bucket)
		{
			while(fhkey == buk_buf[m].nth_bucket)
			{
				n = 0;
				while( n < HASH_SPACE )
				{
					if(add_in_which(buk_buf[m].buk.hk_addr[n].hkey, hash_info.hkey_i) == hash_info.bucket_no - 1)
					{
						found = 0;
						p = 0;
						while( p < HASH_SPACE )
						{
							if(bucket.buk.hk_addr[p].hkey == -1)
							{
								bucket.buk.hk_addr[p] = buk_buf[m].buk.hk_addr[n];
								buk_buf[m].buk.hk_addr[n].hkey = -1;
								buk_buf[m].buk.hk_addr[n].to_rcd.blk_no = -1;
								buk_buf[m].buk.hk_addr[n].to_rcd.offset = -1;
								bucket.buk.rcd_no++;
								found = 1;
								break;
							}
							p++;
						}
						if(found == 0)
						{
							bucket.buk.blk_no = length;
							write_idx("hash_table.idx", bucket.from_blk_no);
							fp = fopen("hash_table.idx", "rb+");
							get_blk(fp);
							fclose(fp);
							read_idx("hash_table.idx", hash_info.bucket_no - 1, length);
							bucket.buk.blk_no = -1;
							bucket.buk.rcd_no = 1;
							bucket.buk.hk_addr[0] = buk_buf[m].buk.hk_addr[n];
						}
						buk_buf[m].buk.rcd_no--;
						buk_buf[m].change_flag = 1;
					}
					n++;
				}
				m++;
			}
			m--;
		}
		m++;
	}
	
	for( i = 0; i < BUCKET_BUFFER_SIZE; i++)
		if(buk_buf[i].change_flag == 1)
			write_idx("hash_table.idx", buk_buf[i].from_blk_no);
	
	for(i = 0; i < BUCKET_BUFFER_SIZE; i++)
	{
		buk_buf[i].from_blk_no = -1;
		buk_buf[i].change_flag = 0;
	}		
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线网站| 精品日韩欧美在线| 欧美xxx久久| 最新日韩av在线| 久久精品国产在热久久| 99久久精品国产麻豆演员表| 欧美电影在线免费观看| 国产精品麻豆网站| 蜜桃视频一区二区三区在线观看| 99久久久免费精品国产一区二区| 67194成人在线观看| 日韩毛片一二三区| 狠狠网亚洲精品| 777久久久精品| 一区二区三区成人在线视频| 不卡一区二区中文字幕| 精品免费日韩av| 全部av―极品视觉盛宴亚洲| 色婷婷亚洲精品| 国产精品福利一区二区三区| 国产一区二区三区免费在线观看| 欧美一区二区大片| 五月婷婷综合激情| 欧美日韩一区二区欧美激情| 亚洲欧美日韩在线不卡| 成人精品视频一区| 国产日韩精品一区二区三区| 麻豆成人久久精品二区三区小说| 欧美另类videos死尸| 亚洲黄色av一区| 一本一道综合狠狠老| 中文字幕一区二区三| 97se亚洲国产综合在线| 国产精品无人区| 成人网页在线观看| 国产欧美日韩三级| 欧美四级电影在线观看| 亚洲午夜三级在线| 欧美性受xxxx| 亚洲小说欧美激情另类| 欧美精品自拍偷拍| 日韩制服丝袜先锋影音| 欧美一卡2卡3卡4卡| 免费人成黄页网站在线一区二区| 日韩欧美国产不卡| 国产一区二区毛片| 国产精品国产三级国产专播品爱网 | 在线观看免费视频综合| 亚洲人123区| 欧美三级电影精品| 青青草国产成人99久久| 久久影院电视剧免费观看| 国产一区二区三区四区五区入口 | 国产偷国产偷精品高清尤物| 成人免费观看男女羞羞视频| 亚洲欧美另类久久久精品2019| 欧美在线观看你懂的| 男人的j进女人的j一区| 国产三级精品三级在线专区| 99久久国产免费看| 婷婷激情综合网| 久久综合色之久久综合| 白白色亚洲国产精品| 亚洲福利视频一区二区| 久久天天做天天爱综合色| 成人h动漫精品一区二| 日一区二区三区| 精品久久人人做人人爽| 色偷偷久久一区二区三区| 五月天激情综合网| 久久精品免费在线观看| 欧洲视频一区二区| 国精产品一区一区三区mba视频| 国产精品激情偷乱一区二区∴| 欧美三级三级三级| 高清av一区二区| 亚洲高清视频的网址| 中文字幕久久午夜不卡| 91精品国产综合久久小美女| 成人一区二区视频| 舔着乳尖日韩一区| 中文字幕欧美区| 91精品国产色综合久久| 99视频精品在线| 极品少妇xxxx精品少妇偷拍| 一区二区三区日韩欧美| 久久精品日韩一区二区三区| 欧美日韩国产大片| 色综合久久综合中文综合网| 韩国成人福利片在线播放| 一区二区三区欧美视频| 中日韩av电影| 久久嫩草精品久久久精品| 欧美理论在线播放| 91麻豆高清视频| 国产成人aaa| 国产在线不卡一区| 国产精品一级二级三级| 久久国产精品72免费观看| 亚洲永久精品国产| 亚洲欧美aⅴ...| 中文字幕欧美国产| 久久久久九九视频| 欧美va亚洲va在线观看蝴蝶网| 欧美色电影在线| 在线观看成人免费视频| 91福利国产精品| 色天天综合久久久久综合片| proumb性欧美在线观看| 丁香婷婷综合五月| 国产成人丝袜美腿| 国产高清久久久| 国产一二精品视频| 国产乱人伦偷精品视频不卡| 国产剧情一区在线| 国产又粗又猛又爽又黄91精品| 午夜精品一区二区三区免费视频| 一区二区三区视频在线观看| 一区二区三区欧美在线观看| 亚洲免费观看高清在线观看| 亚洲欧美偷拍卡通变态| 成人欧美一区二区三区视频网页| 国产精品麻豆视频| 亚洲精品视频免费看| 一区二区三区中文字幕| 无码av免费一区二区三区试看| 日本网站在线观看一区二区三区 | 成人av在线一区二区三区| 成人性色生活片免费看爆迷你毛片| 国产剧情一区在线| av午夜一区麻豆| 在线免费观看视频一区| 欧美日韩亚洲丝袜制服| 欧美精品丝袜中出| 精品日韩欧美一区二区| 日本一区二区三区dvd视频在线| 久久精品综合网| 亚洲欧美激情小说另类| 天天综合色天天综合| 国产又黄又大久久| 色天天综合久久久久综合片| 91精品免费在线| 国产清纯白嫩初高生在线观看91 | 在线视频你懂得一区二区三区| 色美美综合视频| 日韩一级免费观看| 国产欧美一区在线| 亚洲高清免费在线| 国产一区二区三区在线观看免费视频 | 久久综合久久综合亚洲| 国产精品三级视频| 亚洲一区二区三区视频在线播放 | 在线成人av网站| 精品精品国产高清a毛片牛牛| 国产精品网友自拍| 日韩精品乱码av一区二区| 国产成人啪免费观看软件 | 久久精品人人爽人人爽| 亚洲黄色片在线观看| 国产尤物一区二区| 欧美久久久一区| 亚洲男同性恋视频| 精品一区二区在线免费观看| 99久久久精品免费观看国产蜜| 日韩一区二区精品在线观看| 亚洲色图制服诱惑 | 久久精品国产第一区二区三区| 国产成人精品免费网站| 欧美日韩高清一区二区不卡 | 日本一区二区电影| 日韩精品欧美精品| 日本乱人伦aⅴ精品| 久久影院视频免费| 亚洲福利电影网| 国产一区二区女| 日韩欧美国产三级| 亚洲伦在线观看| 成人深夜在线观看| 日韩欧美一区中文| 亚洲女性喷水在线观看一区| 三级久久三级久久| www.欧美日韩国产在线| 日韩久久精品一区| 久久久久成人黄色影片| 老汉av免费一区二区三区| 91在线免费播放| 欧美一级国产精品| 日本aⅴ亚洲精品中文乱码| av在线一区二区三区| 日韩美女视频一区二区在线观看| 中文字幕不卡在线观看| 国产99久久精品| 911国产精品| 亚洲人成亚洲人成在线观看图片| 国产成人8x视频一区二区| 欧美一区二区三区免费视频| 亚洲精品中文字幕在线观看| 91视频国产观看| 亚洲国产精品国自产拍av| 久久精品国产一区二区三区免费看 |