php随机取mysql记录方法示例
方法一:
代码如下 | 复制代码 |
select * from tablename order by rand() limit 1 |
把 limit 后面的数值改为你想随机抽取的条数,这里只取一条。
方法二:
代码如下 | 复制代码 |
$query= "SELECT count(*) as count FROM recommends"; $query = "SELECT * FROM recommendsn limit ".$se_pos.",".$length; |
例3
假设有一个名为xyj的数据库,库中有表obj,表中有一字段为name,现在要实现从表里随机选取一条记录,具体程序如下:
代码如下 | 复制代码 |
<?php $db = mysql_connect("localhost", "root"); mysql_select_db("xyj",$db); $result=mysql_query("SELECT * FROM obj",$db); $max_num=mysql_num_rows($result);//取得数据库的记录数 srand((double)microtime()*10000000); //生成随机数种子。 $se_pos=rand(0, $max_num-1); //从0到最大记录数取随机数 $length=30; //设定共取多少条记录 //下面是取出指定数目的记录。 $result_lim=mysql_query("select * from obj limit $se_pos,$length",$db); $myrow_lim=mysql_fetch_array($result_lim); printf("%sn", $se_pos);//显示随机得到的记录号 printf("%sn", $myrow_lim["name"]);//显示随机得到的记录的name字段 |
PHP 备份 mysql 数据库的源代码,在完善的 PHP+Mysql 项目中,在后台都会有备份 Mysql 数据库的功能,有了这个功能,我们就不用再使用 FTP 或者使用 mysql 的管理工具进行 mysql 数据库下载了,非常方便,对于想做这样功能的 phper 来说,其实原理并不是很麻烦,主要有以下三点:
一,一定要连接数据库,这样才能通过 SQL 语句打印出 mysql 数据表,二,通过 PHP 的文件操作函数进行数据库的操作,包括创建保存 mysql 数据库的文件夹,这一步主要就是新建文件的步骤,三,将 mysql 数据库进行保存下来。
通过这样的原理,我们就可以制作出一个属于自己的备份数据库的功能了,下面是一个php数据库备份的源代码,主要结构是依据上面的三点进行的,源码是由几个方法组成的,我们也可以将其封装成为自己的 php 类。举一反三,希望 phper 能在此基础上设计出适合自己的 mysql 数据库备份功能源码
代码如下 | 复制代码 |
<?php //判断文件是否存在 //判断文件是否可写 if(!fwrite($handle,$content)){ //关闭文件流
/** while ($row = $rows->fetch_row()){ |
数据库备份类
使用方法:
代码如下 | 复制代码 |
require_once("backdata.class.php"); $dbbck = new backupData($link);//实例化它,只要一个链接标识就行了 //备份数据时,如想备份一个数据库中的所有表,你可这样写: //备份数据时,如想备份一个数据库中的仅一个表时,你可这样写: //备份数据时,如想备份一个数据库中的多个表时,你可这样写: //注解:$dbbck->backupTables("参1","参2",array());中, |
参1为:数据库名,
参2为:要存放备份数据的位置(即目录地址)
第三个为:你要保存那些表
backdata.class.php
代码如下 | 复制代码 |
<?php public function __construct($mysql_link){ |
PDO::exec
返回的是int类型,表示影响结果的条数。
PDOStatement::execute
返回的是boolean型,true表示执行成功,false表示执行失败。
这两个通常出现在:
代码如下 | 复制代码 |
$rs0 = $pdo->exec($sql); |
一般情况下可以用$rs0的值判断SQL执行成功与否,如果其值为false表示SQL执行失败,0表示没有任何更改,大于0的值表示影响了多少条记录。
但是$rs1只能返回SQL执行成功与否,如果需要获取影响的记录数需要使用$pre->rowCount();
我个人喜欢使用 MySQL,所以我的 extensions.ini 中有这二行
extension=pdo.so
extension=pdo_mysql.so
接著在程式中,我们需要宣告 PDO ?⒍?墓δ?/p>
代码: [选择]
代码如下 | 复制代码 |
define('DB_NAME','test'); |
文中的使用常数设定是我个人的习惯,各位不用像我这?麻烦
当像上面的操作,$dbh 本身就是代表了PDO的连线了
那要怎?使用PDO呢?
第一式 懒人法 query
什?都不用想,像平常一样的使用 query 的函式
代码: [选择]
代码如下 | 复制代码 |
$sql = 'select * from test'; |
第二式 自动带入法 prepare
我个人使用PDO后,偏好利用 prepare 的函式来进行作动
prepare 的好处是可以先写好 SQL 码,并且在稍后自动带入我们要的资料
这?我想最大的好处是比起直接利用 query 可以减少许多安全性的问题
首先,我们利用 prepare 进行 SQL 码的设定,在利用bindparm 来进行设定的动作
代码: [选择]
代码如下 | 复制代码 |
$sth = $dbh->prepare('update db set zh_CN= :str where SN=:SN'); |
请注意文中的 :str 及 :SN,当我们利用 bindParam的函式,可以利用 :word 来指定系统需要套用的部份,像是我们利用 :str 及 :SN 来指定
而实际的内容,就靠bindParam还可以指定我们要输入的型态。
首先我们先看 :str 的指定,:str 由於我确定资料是属於文字,因此利用 PD::PARAM_STR 来告诉程式“这个是字串哟”,并且给一个范围,也就是长度是12个位元。
我们也可以不要那?复杂,像 :SN ,虽然也是用 bindParam 来指定,但是我们省略了型态及长度,PHP 会用该变数预设的型态来套用。
最后呢,就是利用 $sth->execute(); 来进行执行的动作。
基本上不难,甚至可以说很简单呢!
如果你有大量需要重复套用的资料,你就可以拼了命的重新利用 bindParam 来指定,比如我的 :str 及 :SN 如果有十笔资料,我也可以这样子直接新增到资料库
代码: [选择]
代码如下 | 复制代码 |
$sth = $dbh->prepare('insert into db ("zh_CN","zh_TW")values(:str , :SN'); |
甚至强者如我朋友... 把所有可能的 SQL 全写在一个档案?面,后来的过程SQL的部份就变成全用变数带进去了!
反正资料可以用现成的方式套用嘛!
那,如果利用 prepare 的方式来 select ,关键字当然也可以像上面的方式利用 :word 来指定
代码: [选择]
代码如下 | 复制代码 |
$sth = $dbh->prepare('select * from db where SN = :SN'); |
这?新出现的是 fetch,跟mysql_fetch_row() 的意思差不多
但是在 fetch() 中我们发现多了一个 PDO::FETCH_ASSOC 这个东西
fetch() 提供了许多获取资料的方式,而 PDO::FETCH_ASSOC 指的就是传回下一笔资料的栏位名及值啦
比如上例,利用 $meta 来取得 fetch 传回的资料,此时
$meta 的元素名称就是资料库的栏位名称,而内容当然就是值本身
这个跟你利用 mysql_fetch_row() 时不一样,因为除了栏位名称,mysql_fetch_row() 还会依照顺利
将元素名称除了栏位外在多给予一个以序号的方式为基础的元素,那难道 PDO 没有吗?
当然有,只要将 PDO::FETCH_ASSOC 改为 PDO::FETCH_BOTH,那用法就跟 mysql_fetch_row() 没什?俩样了。
如何除错
除错是所有程式设计师中心中永远的痛,我们使用 PDO 要如何除错呢?
其实 PDO 已经提供了二个非常方便的函式
errorInfo() 及 errorCode()
用法也是世界简单,每当我们利用 execute() 执行后,如果有错误
那 errorInfo() 及 errorCode() 中就会有内容
我们就可以这样子做啦....
代码: [选择]
代码如下 | 复制代码 |
$sth = $dbh->prepare('select * from db where SN = :SN'); |
而 $sth->errorInfo() 会是一个阵列,这个阵列有三个值
0 为SQLSTATE error code
1 为你所使用的 Driver 所传回的错误码
2 为你所使用的 Driver 所传回的错误讯息
实例一
代码如下 | 复制代码 |
<?php $conn = mssql_connect($hostname,$dbuser,$dbpasswd); //连接MSSQL { ?> |
参考代码二、
代码如下 | 复制代码 |
<?php $mssql_link = mssql_connect($db_host,$db_msuser,$db_mspass) or mssql_select_db($db_msname,$mssql_link); $mysql_link = mysql_connect($db_myhost,$db_myuser,$db_mypass) or die("mysql数据库连接失败".mysql_error()); mysql_select_db($db_myname,$mysql_link); $msquery = mssql_query("select top 1 * from buyok_produc",$mssql_link); $vars = ”; while ($row = mssql_fetch_array($msquery,$mssql_link)){ $sql = echo $sql; $aa=mysql_query($sql, $mysql_link); if ($aa){ ?> |
相关文章
php 中file_get_contents超时问题的解决方法
file_get_contents超时我知道最多的原因就是你机器访问远程机器过慢,导致php脚本超时了,但也有其它很多原因,下面我来总结file_get_contents超时问题的解决方法总结。...2016-11-25- php如何实现抓取网页图片,相较于手动的粘贴复制,使用小程序要方便快捷多了,喜欢编程的人总会喜欢制作一些简单有用的小软件,最近就参考了网上一个php抓取图片代码,封装了一个php远程抓取图片的类,测试了一下,效果还不错分享...2015-10-30
- 相信很多站长都遇到过这样一个问题,访问页面时出现408错误,下面一聚教程网将为大家介绍408错误出现的原因以及408错误的解决办法。 HTTP 408错误出现原因: HTT...2017-01-22
- 下面我们来看一篇关于Android子控件超出父控件的范围显示出来方法,希望这篇文章能够帮助到各位朋友,有碰到此问题的朋友可以进来看看哦。 <RelativeLayout xmlns:an...2016-10-02
- ps软件是现在非常受大家喜欢的一款软件,有着非常不错的使用功能。这次文章就给大家介绍下ps把文字背景变透明的操作方法,喜欢的一起来看看。 1、使用Photoshop软件...2017-07-06
intellij idea快速查看当前类中的所有方法(推荐)
这篇文章主要介绍了intellij idea快速查看当前类中的所有方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-09-02- 1.在没有设置默认值的情况下: 复制代码 代码如下:SELECT userinfo.id, user_name, role, adm_regionid, region_name , create_timeFROM userinfoLEFT JOIN region ON userinfo.adm_regionid = region.id 结果:...2014-05-31
js导出table数据到excel即导出为EXCEL文档的方法
复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta ht...2013-10-13- 批量更新mysql更新语句很简单,更新一条数据的某个字段,一般这样写:复制代码 代码如下:UPDATE mytable SET myfield = 'value' WHERE other_field = 'other_value';如果更新同一字段为同一个值,mysql也很简单,修改下where即...2013-10-04
- ps软件是一款非常不错的图片处理软件,有着非常不错的使用效果。这次文章要给大家介绍的是ps怎么制作倒影,一起来看看设计倒影的方法。 用ps怎么做倒影最终效果̳...2017-07-06
- 本文涉及的主题虽然很基础,在许多人看来属于小伎俩,但在JavaScript基础知识中属于一个综合性的话题。这里会涉及到对象属性的封装、原型、构造函数、闭包以及立即执行表达式等知识。公有方法 公有方法就是能被外部访问...2015-11-08
安卓手机wifi打不开修复教程,安卓手机wifi打不开解决方法
手机wifi打不开?让小编来告诉你如何解决。还不知道的朋友快来看看。 手机wifi是现在生活中最常用的手机功能,但是遇到手机wifi打不开的情况该怎么办呢?如果手机wifi...2016-12-21- 最近想自学PHP ,做了个验证码,但不知道怎么搞的,总出现一个如下图的小红叉,但验证码就是显示不出来,原因如下 未修改之前,出现如下错误; (1)修改步骤如下,原因如下,原因是apache权限没开, (2)点击打开php.int., 搜索extension=ph...2013-10-04
- 单个字符分割 string s="abcdeabcdeabcde"; string[] sArray=s.Split('c'); foreach(string i in sArray) Console.WriteLine(i.ToString()); 输出下面的结果: ab de...2020-06-25
- javascript控制页面控件隐藏显示的两种方法,方法的不同之处在于控件隐藏后是否还在页面上占位 方法一: 复制代码 代码如下: document.all["panelsms"].style.visibility="hidden"; document.all["panelsms"].style.visi...2013-10-13
连接MySql速度慢的解决方法(skip-name-resolve)
最近在Linux服务器上安装MySql5后,本地使用客户端连MySql速度超慢,本地程序连接也超慢。 解决方法:在配置文件my.cnf的[mysqld]下加入skip-name-resolve。原因是默认安装的MySql开启了DNS的反向解析。如果禁用的话就不能...2015-10-21- 本篇文章是对C#方法进行了详细的总结与介绍,需要的朋友参考下...2020-06-25
- 步骤:Window -> PHP -> Editor -> Templates,这里可以设置(增、删、改、导入等)管理你的模板。新建文件注释、函数注释、代码块等模板的实例新建模板,分别输入Name、Description、Patterna)文件注释Name: 3cfileDescriptio...2013-10-04
- EXCEL数据上传到SQL SERVER中的方法需要注意到三点!注意点一:要把EXCEL数据上传到SQL SERVER中必须提前把EXCEL传到服务器上.做法: 在ASP.NET环境中,添加一个FileUpload上传控件后台代码的E.X: 复制代码 代码如下: if...2013-09-23
- 这篇文章主要介绍了超简洁java实现双色球若干注随机号码生成(实例代码),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-04-02