需要PHP基础知识和数据库基础知识.
mysql_connect() 函数打开MySQL 连接.举例
php
$con = mysql_connect("localhost","mysql_user","mysql_pwd");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}// 一些代码...mysql_close($con);
mysql_connect()三个参数分别是服务器名,连接账号,连接密码.
连接之后,可以使用mysql_select_db()设置要处理的数据库,后面则是用数据库语句处理数据.SQL语法简介网页链接
php实现上传图片保存到数据库的方法.具体分析如下:
php 上传图片,一般都使用move_uploaded_file方法保存在服务器上.但如果一个网站有多台服务器,就需要把图片发布到所有的服务器上才能正常使用(使用图片服务器的除外)
如果把图片数据保存到数据库中,多台服务器间可以实现文件共享,节省空间.
首先图片文件是二进制数据,所以需要把二进制数据保存在mysql数据库.
mysql数据库提供了BLOB类型用于存储大量数据,BLOB是一个二进制对象,能容纳不同大小的数据.
BLOB类型有以下四种,除存储的最大信息量不同外,其他都是一样的.可根据需要使用不同的类型.
数据表photo,用于保存图片数据,结构如下:
CREATE?TABLE?+photo+?(?
+id+?int(10)?unsigned?NOT?NULL?auto_increment,?
+type+?varchar(100)?NOT?NULL,?
+binarydata+?mediumblob?NOT?NULL,?
PRIMARY?KEY?(+id+)?
)?ENGINE=MyISAM?DEFAULT?CHARSET=latin1?AUTO_INCREMENT=1?;
upload_image_todb.php代码如下:
php?
//?连接数据库?
@mysql_select_db('demo',$conn)?or?die(mysql_error());?//?判断action?
$action?=?isset($_REQUEST['action'])?$_REQUEST['action']?:?'';?
//?上传图片?
if($action=='add'){?
$image?=?mysql_escape_string(file_get_contents($_FILES['photo']['tmp_name']));?
$type?=?$_FILES['photo']['type'];?
$sqlstr?=?"insert?into?photo(type,binarydata)?values('".$type."','".$image."')";?
header('location:upload_image_todb.php');?
exit();?
//?显示图片?
}elseif($action=='show'){?
$id?=?isset($_GET['id'])?intval($_GET['id'])?:?0;?
$sqlstr?=?"select?*?from?photo?where?id=$id";?
$query?=?mysql_query($sqlstr)?or?die(mysql_error());?
$thread?=?mysql_fetch_assoc($query);?
if($thread){?
header('content-type:'.$thread['type']);?
echo?$thread['binarydata'];?
}?
}else{?
//?显示图片列表及上传表单?
html?
head?
title?upload?image?to?db?demo?/title?
/head?
body?
form?name="form1"?method="post"?action="upload_image_todb.php"?enctype="multipart/form-data"?
p图片:input?type="file"?name="photo"/p?
pinput?type="hidden"?name="action"?value="add"input?type="submit"?name="b1"?value="提交"/p?
/form?
$sqlstr?=?"select?*?from?photo?order?by?id?desc";?
$result?=?array();?
while($thread=mysql_fetch_assoc($query)){?
$result[]?=?$thread;?
foreach($result?as?$val){?
echo?'pimg?
src="upload_image_todb.php?action=showid='.$val['id'].'t='.time().'"
/body?
/html?
程序运行截图和数据库截图:
当你问到这个问题的时候,其实我是不想回答的
你应该是个小白,因为 "文件地址"这个其实就是一个URL,就是一个字符串.把"
文件地址上传到数据库",其实就是把一个字符串插入到相应的表.如果你有基础,文件都上传了获取到路径了,就等插入数据库,根本不会来问这个问题.如果你没基础,那不是我今天这一节三言两语甚至长篇大论能教会你的.
我只能大概说一下思路:
①.、首先,建表,数据库新建一个表来存放这个文件地址
完了!
以上就是土嘎嘎小编为大家整理的php怎么上传数据库相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!