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

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

?? database.php

?? GForge 3.0 協作開發平臺 支持CVS, mailing lists, bug tracking, message boards/forums, task management, perman
?? PHP
字號:
<?php/** * database.php - The database abstraction library * This is the PostgreSQL version of our database connection/querying layer * * Copyright 1999-2001 (c) VA Linux Systems * * @version   $Id: database.php,v 1.10 2001/06/22 17:58:20 tperdue Exp $ * * This file is part of GForge. * * GForge is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * GForge is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with GForge; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA *///$conn - database connection handle/** * Current row for each result set * * @var			array	$sys_db_row_pointer */$sys_db_row_pointer=array(); //current row for each result set/** * pg_connectstring() - builds a postgres connection string. * Combines the supplied arguments into a valid, specific, postgresql * connection string. It only includes the host and port options * if specified. Without those options, it will use the unix domain * sockets to connect to the postgres server on the local machine. * * @author	Graham Batty graham@sandworm.ca * @param	dbname		The database to connect to. Required. * @param	user		The username used to connect. Required * @param	password	The password used to connect * @param	host		The hostname to connect to, if not localhost * @param	port		The port to connect to, if not 5432 * @return	string		The connection string to pass to pg_connect() * @date	2003-02-12 */function pg_connectstring($dbname, $user, $password = "", $host = "", $port = "") {	$string = "dbname=$dbname user=$user";	if ($password != "")		$string .= " password=$password";	if ($host != "") {		$string .= " host=$host";		if ($port != "")			$string .= " port=$port";	}	return $string;}/** *  db_connect() - Connect to the database *  Notice the global vars that must be set up *  Sets up a global $conn variable which is used  *  in other functions in this library. */function db_connect() {	global $sys_dbhost,$sys_dbuser,$sys_dbpasswd,$conn,		$sys_dbname,$sys_db_use_replication,$sys_dbport,$sys_dbreaddb,$sys_dbreadhost;	//	//	Connect to primary database	//	$conn = @pg_pconnect(pg_connectstring($sys_dbname, $sys_dbuser, $sys_dbpasswd, $sys_dbhost, $sys_dbport));	//	//	If any replication is configured, connect	//	if ($sys_db_use_replication) {		$conn2 = @pg_pconnect(pg_connectstring($sys_dbreaddb, $sys_dbuser, $sys_dbpasswd, $sys_dbreadhost, $sys_dbreadport));	} else {		$conn2 = $conn;	}	//	//	Now map the physical database connections to the	//	"virtual" list that is used to distribute load in db_query()	//	define(SYS_DB_PRIMARY,$conn);	define(SYS_DB_STATS,$conn2);	define(SYS_DB_TROVE,$conn2);	define(SYS_DB_SEARCH,$conn2);	// Register top-level "finally" handler to abort current	// transaction in case of error	register_shutdown_function("system_cleanup");}/** *  db_query() - Query the database. * *  @param text SQL statement. *  @param int How many rows do you want returned. *  @param int Of matching rows, return only rows starting here. *	@param int ability to spread load to multiple db servers. *	@return int result set handle. */function db_query($qstring,$limit='-1',$offset=0,$dbserver=SYS_DB_PRIMARY) {	global $QUERY_COUNT;	$QUERY_COUNT++;	if ($limit > 0) {		if (!$offset || $offset < 0) {			$offset=0;		}		$qstring=$qstring." LIMIT $limit OFFSET $offset";	}	$GLOBALS['G_DEBUGQUERY'] .= $qstring .' |<font size="-2">'.$dbserver.'</font>'. "<p>\n";	$res = @pg_exec($dbserver,$qstring);	//echo "<br />|*| ".db_error().$qstring;	return $res;}/* Current transaction level, private variable *//* FIXME: Having scalar variable for transaction level is   no longer correct after multiple database (dbservers) support   introduction. However, it is true that in one given PHP   script, at most one db is modified, so this works for now. */$_sys_db_transaction_level = 0;/** *	db_begin() - Begin a transaction. * *  @param		constant		Database server (SYS_DB_PRIMARY, SYS_DB_STATS, SYS_DB_TROVE, SYS_DB_SEARCH) *	@return true. */function db_begin($dbserver=SYS_DB_PRIMARY) {	global $_sys_db_transaction_level;	// start database transaction only for the top-level	// programmatical transaction	$_sys_db_transaction_level++;	if ($_sys_db_transaction_level == 1) {		return db_query("BEGIN WORK", -1, 0, $dbserver);	}	return true;}/** *	db_commit() - Commit a transaction. * *  @param		constant		Database server (SYS_DB_PRIMARY, SYS_DB_STATS, SYS_DB_TROVE, SYS_DB_SEARCH) *	@return true on success/false on failure. */function db_commit($dbserver=SYS_DB_PRIMARY) {	global $_sys_db_transaction_level;	// check for transaction stack underflow	if ($_sys_db_transaction_level == 0) {		echo "COMMIT underflow<br />";		return false;	}	// commit database transaction only when top-level	// programmatical transaction ends	$_sys_db_transaction_level--;	if ($_sys_db_transaction_level == 0) {		return db_query("COMMIT", -1, 0, $dbserver);	}	return true;}/** *	db_rollback() - Rollback a transaction. * *  @param		constant		Database server (SYS_DB_PRIMARY, SYS_DB_STATS, SYS_DB_TROVE, SYS_DB_SEARCH) *	@return true on success/false on failure. */function db_rollback($dbserver=SYS_DB_PRIMARY) {	global $_sys_db_transaction_level;	// check for transaction stack underflow	if ($_sys_db_transaction_level == 0) {		echo "ROLLBACK underflow<br />";		return false;	}	// rollback database transaction only when top-level	// programmatical transaction ends	$_sys_db_transaction_level--;	if ($_sys_db_transaction_level == 0) {		return db_query("ROLLBACK", -1, 0, $dbserver);	}	return true;}/** *	db_numrows() - Returns the number of rows in this result set. * *	@param		int		Query result set handle. *	@return int number of rows. */function db_numrows($qhandle) {	return @pg_numrows($qhandle);}/** *  db_free_result() - Frees a database result properly. * *	@param		int		Query result set handle. */function db_free_result($qhandle) {	return @pg_freeresult($qhandle);}/** *  db_reset_result() - Reset is useful for db_fetch_array *  sometimes you need to start over. * *	@param		int		Query result set handle. *  @param		integer	Row number. *	@return int row. */function db_reset_result($qhandle,$row=0) {	global $sys_db_row_pointer;	return $sys_db_row_pointer[$qhandle]=$row;}/** *  db_result() - Returns a field from a result set. * *	@param		int		Query result set handle. *  @param		integer Row number. *  @param		string	Field name. *	@return contents of field from database. */function db_result($qhandle,$row,$field) {	return @pg_result($qhandle,$row,$field);}/** *  db_numfields() - Returns the number of fields in this result set. * *	@param		int		Query result set handle. */function db_numfields($lhandle) {	return @pg_numfields($lhandle);}/** *  db_fieldname() - Returns the number of rows changed in the last query. * *	@param		int		Query result set handle. *  @param		int		Column number. *	@return text name of the field. */function db_fieldname($lhandle,$fnumber) {	return @pg_fieldname($lhandle,$fnumber);}/** *  db_affected_rows() - Returns the number of rows changed in the last query. * *	@param		int		Query result set handle. *	@return int number of affected rows. */function db_affected_rows($qhandle) {	return @pg_cmdtuples($qhandle);}/** *  db_fetch_array() - Returns an associative array from  *  the current row of this database result *  Use db_reset_result to seek a particular row. * *	@param		int		Query result set handle. *	@return associative array of fieldname/value key pairs. */function db_fetch_array($qhandle) {	global $sys_db_row_pointer;	$sys_db_row_pointer[$qhandle]++;	return @pg_fetch_array($qhandle,($sys_db_row_pointer[$qhandle]-1));}/** *  db_insertid() - Returns the last primary key from an insert. * *	@param		int		Query result set handle. *  @param		string	table_name is the name of the table you inserted into. *  @param		string	pkey_field_name is the field name of the primary key. *  @param		string	Server to which original query was made *	@return int id of the primary key or 0 on failure. */function db_insertid($qhandle,$table_name,$pkey_field_name,$dbserver=SYS_DB_PRIMARY) {	$sql="SELECT max($pkey_field_name) AS id FROM $table_name";	//echo $sql;	$res=db_query($sql, -1, 0, $dbserver);	if (db_numrows($res) >0) {		return db_result($res,0,'id');	} else {	//	echo "No Rows Matched";	//	echo db_error();		return 0;	}}/** *  db_error() - Returns the last error from the database. * *  @param		constant		Database server (SYS_DB_PRIMARY, SYS_DB_STATS, SYS_DB_TROVE, SYS_DB_SEARCH) *	@return text error message. */function db_error($dbserver=SYS_DB_PRIMARY) {	return @pg_errormessage($dbserver);}/** *	system_cleanup() - In the future, we may wish to do a number  *	of cleanup functions at script termination. * *	For now, we just abort any in-process transaction. */function system_cleanup() {	global $_sys_db_transaction_level;	if ($_sys_db_transaction_level > 0) {		echo "Open transaction detected!!!";		db_query("ROLLBACK");	}}function db_drop_table_if_exists ($tn) {	$sql = "SELECT COUNT(*) FROM pg_class WHERE relname='$tn';";	$rel = db_query($sql);	echo db_error();	$count = db_result($rel,0,0);	if ($count != 0) {		$sql = "DROP TABLE $tn;";		$rel = db_query ($sql);		echo db_error();	}}function db_drop_sequence_if_exists ($tn) {	$sql = "SELECT COUNT(*) FROM pg_class WHERE relname='$tn';";	$rel = db_query($sql);	echo db_error();	$count = db_result($rel,0,0);	if ($count != 0) {		$sql = "DROP SEQUENCE $tn;";		$rel = db_query ($sql);		echo db_error();	}}?>

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久午夜精品理论片中文字幕| 天天综合日日夜夜精品| 午夜影院在线观看欧美| 国产一区二区三区综合| 欧美视频一区在线观看| 国产精品乱子久久久久| 日本vs亚洲vs韩国一区三区二区| 99国产精品久| 国产欧美精品一区二区色综合朱莉 | 精品国产一区二区三区久久久蜜月| 国产精品的网站| 国产成人免费网站| 精品久久久久久无| 视频一区免费在线观看| 91久久精品日日躁夜夜躁欧美| 久久久www成人免费毛片麻豆| 日本aⅴ精品一区二区三区| 日本精品一区二区三区高清| 中文字幕巨乱亚洲| 国产一区二区网址| 久久无码av三级| 久久99精品久久久久久| 欧美人与性动xxxx| 亚洲午夜久久久久中文字幕久| 91亚洲男人天堂| 国产精品剧情在线亚洲| 国产成人三级在线观看| 久久这里只有精品视频网| 麻豆精品视频在线观看免费 | 欧美大黄免费观看| 日本vs亚洲vs韩国一区三区二区| 欧美精品在线一区二区| 亚洲第一精品在线| 91精品视频网| 美脚の诱脚舐め脚责91| 日韩欧美国产小视频| 久久66热偷产精品| 久久久精品黄色| 国产成人8x视频一区二区| 国产日韩欧美亚洲| 94-欧美-setu| 亚洲一区在线观看网站| 欧美人妖巨大在线| 久久精品国产秦先生| 欧美精品一区二区在线播放| 国产美女av一区二区三区| 欧美激情一二三区| 色综合久久久久网| 免费高清视频精品| 久久综合九色综合97婷婷 | 久久99精品久久只有精品| 久久欧美一区二区| 99re热视频这里只精品| 亚洲一二三四久久| 欧美成人国产一区二区| 国产mv日韩mv欧美| 亚洲最色的网站| 日韩小视频在线观看专区| 国产毛片精品一区| 曰韩精品一区二区| 日韩一区二区在线免费观看| 国产高清亚洲一区| 一区二区久久久久久| 日韩视频不卡中文| 99精品视频一区二区三区| 亚洲成av人**亚洲成av**| 精品国产一区二区亚洲人成毛片 | 国产精品免费观看视频| 欧美日韩大陆在线| 成人国产精品免费| 奇米影视7777精品一区二区| 久久久不卡网国产精品二区| 91国偷自产一区二区使用方法| 麻豆精品视频在线| 亚洲特黄一级片| 日韩精品综合一本久道在线视频| 成人白浆超碰人人人人| 日本一不卡视频| 亚洲精品自拍动漫在线| 日韩女优电影在线观看| 色婷婷av一区| 国产成a人无v码亚洲福利| 天天综合天天综合色| 亚洲少妇中出一区| 国产三级精品三级在线专区| 91精品黄色片免费大全| 一本一道久久a久久精品综合蜜臀| 久久国产剧场电影| 亚洲成人av免费| 亚洲人成网站色在线观看| 久久综合久久综合久久综合| 欧美另类高清zo欧美| 91在线丨porny丨国产| 激情av综合网| 日本vs亚洲vs韩国一区三区 | 久久99国内精品| 午夜日韩在线电影| 亚洲男人的天堂av| 中文子幕无线码一区tr| 久久品道一品道久久精品| 日韩一区二区影院| 欧美精品tushy高清| 欧美系列在线观看| 色综合av在线| 色综合 综合色| 99国产精品久久久久久久久久 | 日av在线不卡| 天天爽夜夜爽夜夜爽精品视频| 亚洲精品高清在线| 亚洲精品五月天| 尤物视频一区二区| 亚洲国产成人高清精品| 亚洲永久免费av| 亚洲另类在线视频| 一区二区三区在线播| 亚洲一区二区五区| 亚洲成av人片在线| 奇米影视7777精品一区二区| 久久精品久久99精品久久| 日本aⅴ免费视频一区二区三区| 日韩黄色小视频| 美国欧美日韩国产在线播放| 免费高清成人在线| 国产91综合一区在线观看| 精品综合免费视频观看| 精品一区二区综合| 国产激情一区二区三区| 成人性色生活片免费看爆迷你毛片| 国产一区二区三区高清播放| 国产精品一区二区久久精品爱涩| 国产suv精品一区二区三区| 成人免费毛片a| 色播五月激情综合网| 欧美三级日韩在线| 精品乱码亚洲一区二区不卡| 国产网红主播福利一区二区| 中文字幕一区二区三区视频| 亚洲美女屁股眼交| 麻豆精品一区二区三区| 国产99久久久国产精品潘金网站| 91丨porny丨户外露出| 制服丝袜中文字幕一区| 久久久久久一二三区| 亚洲人亚洲人成电影网站色| 亚洲一本大道在线| 国产在线观看一区二区| 色综合天天综合在线视频| 欧美精品一二三| 国产日韩欧美亚洲| 亚洲一卡二卡三卡四卡| 国产精品综合久久| 欧美色视频在线| 国产性做久久久久久| 亚洲va天堂va国产va久| 国产一区二区久久| 欧美亚洲国产bt| 国产日韩成人精品| 日产国产欧美视频一区精品 | 色欧美乱欧美15图片| 日韩午夜精品视频| 亚洲精品欧美综合四区| 国产在线精品一区二区| 在线观看欧美精品| 国产欧美视频一区二区| 午夜成人免费视频| 91一区二区三区在线观看| 欧美一区二视频| 亚洲乱码一区二区三区在线观看| 精品在线亚洲视频| 欧美日韩精品久久久| 国产精品全国免费观看高清| 日韩av一级片| 欧美综合一区二区三区| 欧美韩国日本综合| 国产最新精品精品你懂的| 欧美色中文字幕| 亚洲欧洲国产日韩| 国产成人av电影在线播放| 日韩欧美一区二区三区在线| 亚洲综合色婷婷| 99国产精品国产精品久久| 国产日韩影视精品| 久久不见久久见中文字幕免费| 欧美天堂一区二区三区| 亚洲日本va在线观看| 国产91对白在线观看九色| 2024国产精品视频| 国产在线精品一区在线观看麻豆| 欧美伦理电影网| 午夜国产精品一区| 欧美日韩一区精品| 亚洲高清不卡在线| 欧美日韩亚洲国产综合| 亚洲一区日韩精品中文字幕| 91色在线porny| 亚洲卡通动漫在线| 欧日韩精品视频| 亚洲电影在线播放| 欧美久久高跟鞋激| 免费黄网站欧美|