php调用数据库文章 php调用mysql数据库
dedecms数据库,用php调用sql最新文章
这是我之前写的一个类,和你的需稿团求基本一样,你拿去自己改改吧
为抚顺县等地区用户提供了全套网页设计制作服务,及抚顺县网站建设行业解决方案。主营业务为成都做网站、网站制作、成都外贸网站建设、抚顺县网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
?php
$GLOBALS['web_channel_dir'] = 'dir/inc';
//设置系统根路径
define('WEB_ROOT', $GLOBALS['web_channel_dir'] ? substr(dirname(__FILE__), 0, - strlen($GLOBALS['web_channel_dir'])) : dirname(__FILE__) . '磨含/'键游橘);
abstract class BaseDataQuery
{
/*
* 构造方法
*/
function __construct($pid,$cid,$xid)
{
if(!file_exists(WEB_ROOT . 'data/common.inc.php'))
{
echo "配置错误";
exit();
}else{
require_once WEB_ROOT . 'data/common.inc.php';
}
$this-cfg_dbhost = $cfg_dbhost;
$this-cfg_dbname = $cfg_dbname;
$this-cfg_dbuser = $cfg_dbuser;
$this-cfg_dbpwd = $cfg_dbpwd ;
$this-cfg_dbprefix = $cfg_dbprefix;
$this-cfg_db_language = $cfg_db_language;
$this-link =$this-connect();
}
function connect()
{
//global $link, $host, $dbuser, $dbpasswd, $db;
$link = mysql_connect($this-cfg_dbhost, $this-cfg_dbuser, $this-cfg_dbpwd) or
die("Could not connect: " . mysql_error() . " " . $sql);
mysql_select_db($this-cfg_dbname);
mysql_query("SET NAMES UTF8"); //设置数据库的要查询结果的字符集
return $link;
}
function Query($sql)
{
if(!$this-link)
$this-link = $this-connect();
$result = mysql_query($sql, $this-link) or
die("Could not query: " . mysql_error() . " " . $sql);
return $result;
}
function getAll($sql)
{
$res = $this-Query($sql);
if ($res !== false)
{
$arr = array();
while ($row = mysql_fetch_assoc($res))
{
$arr[] = $row;
}
return $arr;
}
else
{
return false;
}
}
function getAll_cache($sql)
{
$res = $this-Query($sql);
if ($res !== false)
{
$arr = array();
while ($row = mysql_fetch_assoc($res))
{
$arr[] = $row;
}
return $arr;
}
else
{
return false;
}
}
function getOne($sql, $limited = false)
{
if ($limited == true)
{
$sql = trim($sql . ' LIMIT 1');
}
$res = $this-Query($sql);
if ($res !== false)
{
$row = mysql_fetch_row($res);
if ($row !== false)
{
return $row[0];
}
else
{
return '';
}
}
else
{
return false;
}
}
/**
* 得到子栏目ID
* $reid 上线id
*/
function get_child($reid)
{
$child_sql = "SELECT id FROM dede_arctype WHERE reid = ". $reid;
$res =$this-getAll($child_sql);
if(empty($res)){
return $reid;
}
foreach ($res AS $row)
{
if(!empty($row['id']))
{
$arr[] = $row['id'];
$this-get_child($row['id']);
}
}
$str = join(",",$arr);
return $str;
}
/**
* 得到子栏目名称与id
* $reid 上级id
*/
function get_child_name($reid)
{
$child_sql = "SELECT id,typename,reid FROM dede_arctype WHERE reid = ". $reid;
$res =$this-getAll($child_sql);
return $res;
}
function get_ic_name($id)
{
$child_sql = "SELECT typename FROM dede_arctype WHERE id = ". $id;
$res =$this-getAll($child_sql);
return $res;
}
/*
*数据查询
*$flag (需要查询的标记例 头条[h]推荐[c]幻灯[f]特荐[a]滚动[s]加粗[b]图片[p]跳转[j] )
*$typeid 需要查询的栏目id(22,23,24,25)
*$len 需要查询的数据长度 如果$len是数据就是limit 1,100 形式 如果是字符 就是limit 100 如果$len不存就是不限止条数
**/
function query_data($queryInfo)
{
$queryInfo['flag'] ? $flag = $queryInfo['flag'] :$flag = false;
$typeid = $queryInfo['typeid'];
$queryInfo['len'] ? $len = $queryInfo['len'] :$len = false;
$field = $queryInfo['field'];
$queryInfo['order'] ? $order = $queryInfo['order'] :$order = false;
$queryInfo['channel'] ? $channel = $queryInfo['channel'] :$channel = false;
$queryInfo['where'] ? $where = " AND ".$queryInfo['where'] :$where = "";
$queryInfo['typeid2'] ? $typeid2 = "AND typeid2 in(".$queryInfo['typeid2'].")" :$typeid2 = "";
$queryInfo['table'] ? $table = $queryInfo['table']:$table = "dede_archives";
//定义查询数据标识(头条,图片,推荐)
if($flag)
{
$flag = "and find_in_set('$flag',flag) ";
}else{
$flag ="";
}
//查询条数
if($len)
{
if(is_array($len))
{
$len = "limit ".$len[0].",".$len[1];
}else{
$len = "limit 0,".$len;
}
}else{
$len = "";
}
//定义排序条件
if(isset($order) is_array($order))
{
$orderarr = array();
foreach ($order as $key=$value)
{
$orderarr[]= $key." ".$value;
}
$orderstr = join(",",$orderarr);
}
elseif($order == 'rand')
{
$orderstr = " rand(),id desc";
}
elseif($order != '')
{
$orderstr = $order;
}
else
{
$orderstr = "pubdate desc";
//$orderstr = $order;
}
//定义查询模型
if($channel)
{
$channel = "AND channel = ".$channel;
}elseif($channel == "null"){
$channel = "";
}
else
{
$channel = "AND channel = 1";
}
//定义查询字段
if($field)
{
if(is_array($field))
{
$field = join(",",$field);
}
$sql = "select ".$field." from ".$table." WHERE arcrank-1 and typeid in(".$typeid.") ".$typeid2.$flag." ".$channel." $where ORDER BY ".$orderstr." ".$len;
}else{
//根剧栏目查询新闻
$sql = "select id,title,pubdate from ".$table." WHERE arcrank-2 and typeid in(".$typeid.") ".$typeid2.$flag." ".$channel." $where ORDER BY ".$orderstr." ".$len ;
//echo "br/";
}
if($queryInfo['debug']){
$debugstr = "this is Debug:[ $sql ]";
return $debugstr;
}
$result=$this-getAll($sql);
return $result;
}
}
急求php文件的内容调用和mysql内容调用方法
php调用mysql步骤:1、连接MySQL数据库;2、选择MySQL数据库;3、执行SQL语句;4、关闭结果集;5、关闭MySQL服务器。
本文操作环境:windows7系统、PHP7.1版,DELL G3电脑
PHP访问MYSQL数据库的五个步骤详解(图)
数据库在我们PHP日常开发中是必须需要的,那么MYSQL数据库 是一款很多程序员都喜爱的数据库,由于呢 MYSQL 是一个开源的,带一点半商业的,市场的占有率比宏樱野较高,所以一直以来都被认为是 PHP 的最佳搭档,同时 PHP 也具有很强大的数据库支持能力,本篇主要讲解 PHP访问MySQL数据库的基本步骤。
PHP访问MySQL数据库的基本步骤如图所示:
.连接MySQL数据库
使用 mysql_connect()函数建立与MySQL服务器的连接。有关 mysql_connect()函数的使用,我们后面会有详细的介绍。
2.选择MySQL数据库
使用 mysql_select_db()函数选择MySQL数据库服务器的数据库。并与数据库建立连接,有关mysql_select_db()函数的使用,后面我们会有具体详解。
3.执行 SQL 语句蔽喊
在选择数据库中使用 mysql_query()函数执行 SQL语句,对数据的操作方式主要包括 5种方式,下面我们分别进行介绍。查询数据:使用select 语句实现数据的查询功能。
显示数据:使用select 语句显示数据的查询结果。
插入数据:使用insert into 语句向数据库中插入数据。
更新数据:使用update 语句更新数据库中的记录。
删除数据:使用 delete语句删除数据库中的记录!
mysql_query()函数的具体使用后面有具体介绍~
4.关闭结果集
数据库操作完成后,需要关闭结果集,以释放系统资源,语法格式如下:mysql_free_result($result);
技巧:
如果在多个网页中都要频繁进行数据库访问,那么可以建立与数据库服务器的持续连接来提高效率,因为每次与数据库服务器的连接需要较长的时间和交大的资源开销,持续的连接相对来说会更有效率,建立持续连接的方法就是在数据库间接时,调用函数 mysql_pconnect()代替mysql_connect函数。建立的持续连接在本程序结束时,不需要颂晌调用 mysql_colse()来关闭与数据库服务器的连接。下次程序在此执行 mysql_pconnect()函数时,系统自动直接返回已经建立的持续连接ID号,而不再去真的连接数据库。
5.关闭MySQL服务器
没使用一次 mysql_connect()或者mysql_query()函数,都会消耗系统资源,再少量用户放完 web 网站时问题还不大,但如果用户连接超过一定数量时,就会造成系统性能下降,甚至是死机,为了避免这种现象的发生,在完成数据库的操作后,应该使用 mysql_close()函数关闭与MYSQL服务器的连接,以节省系统资源。
语法格式如下:mysql_close($link);
说明:
PHP 中与数据库的连接是非持久连接,系统会自动回收,一般不用设置关闭,但是如果一次性范湖的结果集比较大,或者网站访问量比价多,那么最好使用 mysql_close()函数手动进行释放。
PHP访问MySQL数据库的步骤就结束了,是不是很简单。
推荐学习:《PHP视频教程》
以上就是php调用mysql步骤的详细内容,更多请关注php中文网其它相关文章!
PHP调用三种数据库的方法(3)
Oracle(甲骨文)是世界上最为流行的关系数据库。它是大公司推崇的工业化的强有力的引擎。我们先看看其相关的函数:
(1)integer
ora_logon(string
user
,
string
password)
开始对一个Oracle数据库服务器的连接。
(2)integer
ora_open(integer
connection)
打开给出的连接的游标。
(3)integer
ora_do(integer
connection,
string
query)
在给出的连接上执行查询。PHP生成一个指示器,解析查询,并执行之。
(4)integer
ora_parse(integer
cursor,
string
query)
解析一个查询并准备好执行。
(5)boolean
ora_exec(integer
cursor)
执行一个先皮毕前由ora_parse函数解析过的查询。
(6)boolean
ora_fetch(integer
cursor)
此函数茄握握会使得一个执行过的查询中的行被取到指示器中。这使得您可以调用ora_getcolumn函数。
(7)string
ora_getcolumn(integer
cursor,
integer
column)
返回当前的值。列由零开始的数字索引。
(8)boolean
ora_logoff(integer
connection)
断开对数据库服务器的链接。
以下是向ORACLE数据库插入数据的示例程序:
html
headtitle向ORACLE数据库中插入数据/title/head
body
form
action="?echo
$PHP_SELF;?"
method="post"
table
border="1"
cellspacing="0"
cellpadding="0"
tr
thID/th
thname/th
thDescription/th
/tr
tr
tdinput
type="text"
name="name"
maxlength="50"
size="10"/td
tdinput
type="text"
name="email"
maxlength="255"
size="30"/td
tdinput
type="text"
name="Description"
maxlength="255"
size="50"/td
/tr
tr
align="center"
td
colspan="3"input
type="submit"
value="提交" input
type="reset"
value="重写"/td
/tr
/table
/form
?
//先设置两个环境变量ORACLE_HOME,ORACLE_SID
putenv("ORACLE_HOME=/oracle/app/oracle/product/8.0.4");
putenv("ORACLE_SID=ora8");
//设置网页显示中文
putenv("NLS_LANG=Simplified_Chinese.zhs16cgb231280");
if($connection=ora_logon("scott","颤庆tiger"))
{
//库表test有ID,name,Description三项
$sql
=
'insert
into
test(ID,name,Description)
values
';
$sql
.=
'(''
.
$ID
.
'',''
.
$name
.
'',''.
$Description
.
'')';
if($cursor=ora_do($connect,$sql))
{
print("insert
finished!");
}
$query
=
'select
*
from
test';
if($cursor=ora_do($connect,$query))
{
ora_fetch($cursor);
$content0=ora_getcolumn($cursor,0);
$content1=ora_getcolumn($cursor,1);
$content2=ora_getcolumn($cursor,2);
print("$content0");
print("$content1");
print("$content2");
ora_close($cursor);
}
ora_logoff($connection);
}
?
/body
/html
网站标题:php调用数据库文章 php调用mysql数据库
新闻来源:http://myzitong.com/article/ddpjesp.html