PHP网站制作之本人写的mysql类
刚开始因为习惯于ASP格式的写法,总是在这些方面出现问题,自己还总是找不到问题所在,这就提醒了自己,在写代码的时候一定要认真,不能粗心地老是少个“;”或者字母大小写不分,要不然很可能找半天都找不到错误。mysql ---------- php debug ----------Server=localhost;DataBase=mysql;UserID=root;PassWord=123456
resource(5) of type (mysql result)
Output completed (1 sec consumed) - Normal Termination
<P><?php
class DBCLS
{
#----------------------------------------------------
# 数据库掌握类 DBCLS
# 作者:yms
# yms541@yahoo.com.cn
# 2005-5-30
# 2005-5-31
# php_v5.0.1
# Editplus Text Editer v2.12(76)
#----------------------------------------------------
//debug 调试开关
var $debug = true;
//debuginfo 毛病信息,调试信息
var $debuginfo = "debug informations:\r\n";
//db_server MySQL主机地址
var $db_server;
//db_name 数据库名
var $db_name;
//db_user 数据库用户名
var $db_user;
//db_passwd 暗码
var $db_passwd;
//db_links数据库毗连
var $db_link;
//db_query_sql SQL语句
var $db_query_sql = "show tables";
//db_recordset 了局集,纪录集
var $db_recordset;
//ready 停当开关
var $conntstr_ready = false;
var $link_ready = false;
var $db_ready = false;
//set or return Connection String前往,或设定毗连字符串
function connection_string($connstr="")
{
if("" == $connstr)
{
//假如没有参数传入,前往已有的毗连字符
return "Server=".$this->db_server.";DataBase=".$this->db_name.";UserID=".$this->db_user.";PassWord=".$this->db_passwd;
}
else
{
//不然,解析毗连字符,初始化变量
preg_match_all("|(*)=(*);*|", $connstr, $tmparr, PREG_PATTERN_ORDER);
$this->db_server = (strtolower($tmparr) == "server")?$tmparr:"";
$this->db_name = (strtolower($tmparr) == "database")?$tmparr:"";
$this->db_user = (strtolower($tmparr) == "userid")?$tmparr:"";
$this->db_passwd = (strtolower($tmparr) == "password")?$tmparr:"";
//var_dump($tmparr);
if("" == $this->db_server or "" == $this->db_name or "" == $this->db_user or "" == $this->db_passwd)
$this->conntstr_ready = false; //假如有个中一个以上变量被赋以空字符串"",筹办未停当
else
$this->conntstr_ready = true;
return $this->conntstr_ready;
}
}
//毗连数据库,前往毗连对象
function connect()
{
if(!$this->conntstr_ready)
{
if($this->debug){$this->debuginfo .= "毗连字符串有效!\r\n";}
return $this->link_ready;
}
if($this->db_link = @mysql_connect($this->db_server, $this->db_user, $this->db_passwd))
{
$this->link_ready = true;
return $this->link_ready;
}
}
//选择数据库
function select($db = "")
{
if(!$this->db_link)
{
if($this->debug){$this->debuginfo .= "没有可用的数据库毗连!\r\n";}
$this->db_ready = false;
}
if("" == $db)
{
if(mysql_select_db($this->db_name))
$this->db_ready = true;
}
if(mysql_select_db($this->db_name = $db))
$this->db_ready = true;
return $this->db_ready;
}
//履行查询
function execute($SQL = "")
{
if("" != $SQL)
{
$this->db_query_sql = $SQL;
//if($this->debug){$this->debuginfo .= "SQL is null!\r\n";}
//return false;
}
if("" == $this->db_query_sql)
{
if($this->debug){$this->debuginfo .= "SQL is null!\r\n";}
return false;
}
$this->db_recordset = mysql_query($this->db_query_sql);
return true;
}
}
$dbmy = new DBCLS(); //创立一个DBCLS对象
if(!$dbmy->connection_string("Server=localhost;DataBase=mysql;UserID=root;PassWord=123456"))//初始化DBCLS对象dbmy
print $dbmy->debuginfo; //初始化掉败,输入毛病信息
else
print $dbmy->connection_string(); //初始化胜利,输入毗连字符串
print "\r\n";
if(!($dbmy->connect()) or !($dbmy->select())) //假如毗连数据库,或选择数据库掉败
print $dbmy->debuginfo; //输入失足信息
//$dbmy->db_query_sql = "select * from user";
if($dbmy->execute()) //履行查询指令
{ //假如不失足
var_dump($dbmy->db_recordset);//输入前往的了局集
}
?>
输入信息:
---------- php debug ----------
Server=localhost;DataBase=mysql;UserID=root;PassWord=123456
resource(5) of type (mysql result)
Output completed (1 sec consumed) - Normal Termination
学会了生成静态网页,现在你应该接触一下XML了,恩,XML也了解了,那么AJAX你也得接触接触吧?AJAX完了....然后... 曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线\\\\\\\'_\\\\\\\' ; 找到的的资料很多都是在论坛里的,需要注册,所以我一般没到一个论坛都注册一个id,所有的id都注册成一样的,这样下次再进来的时候就不用重复注册啦。当然有些论坛的某些资料是需要的付费的。 这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己 有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 做为1门年轻的语言,php一直很努力。 Ps:以上纯属原创,如有雷同,纯属巧合 如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域, 有位前辈曾经跟我说过,phper 至少要掌握200个函数 编起程序来才能顺畅点,那些不熟悉的函数记不住也要一拿手册就能找到。所以建议新手们没事就看看php的手册(至少array函数和string函数是要记牢的)。 作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。 真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎, 不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。 开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 建数据库表的时候,int型要输入长度的,其实是个摆设的输入几位都没影响的,只要大于4就行,囧。 如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了, 开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。 为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。 首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
页:
[1]