PHP连接MySQL进行增、删、改、查操作

 更新时间:2017年7月6日 23:49  点击:1885
小编给大家推荐的这篇文章介绍了PHP连接MySQL进行增、删、改、查操作,非常实用,有兴趣的同学可以看看

 

 代码如下 复制代码

<tablewidth="100%"border="1"cellpadding="0"cellspacing="0">

<tr>

<td>代号</td>

<td>姓名</td>

<td>性别</td>

<td>民族</td>

<td>生日</td>

</tr>

<?php

1.造一个mysqli对象,造连接对象

$db=newMySQLi("localhost","用户名","密码","数据库名");

2.准备一条SQL语句

$sql="select * from info";

3.执行SQL语句,如果是查询语句,成功返回结果集对象

$reslut = $db->query($sql);

4.判断返回是否执行成功

if($reslut)

{

while($attr = $reslut->fetch_row())

{

echo "<tr>

<td>{$attr[0]}</td>

<td>{$attr[1]}</td>

<td>{$attr[2]}</td>

<td>{$attr[3]}</td>

<td>{$attr[4]}</td>

</tr>";

}

}

?>

</table>

 

fetch_all()              返回全部数组

fetch_row()            返回索引数组

fetch_assoc()         返回关联数组

fetch_object()        返回对象

fetch_array()          返回的数组既有索引的,又有关联的

数据库的删除,增加,修改操作

 

 代码如下 复制代码

<?php

//造连接对象

$db=newMySQLi("localhost","用户名","密码","数据库名");

//准备SQL语句

$sql="delete from info where code='p004'";    删

//$sql = "insert course values"       增

//$sql = "update 表名 set 字段=信息 where 字段=信息"   改

//执行SQL语句

$r=$db->query($sql);

if($r)

{

echo"执行成功";

}

else

{

echo"执行失败";

}

?>

 

本文介绍了thinkphp标签实现bootsrtap轮播carousel实例代码,非常实用,有兴趣的同学可以参考一下。

由于轮播carousel第一个div需要设置active样式才能正常显示,上面的圆点也同样需要数字,

使用volist标签在循环的同时可以取得下标(foreach,for标签实现不了)

 

 代码如下 复制代码

<div class="Container">

<!-- carousel -->

<div id="carousel-example-generic"class="carousel slide"data-ride="carousel">

<ol class="carousel-indicators">

<volist name="bopic"id="xt">

<li   data-target="#carousel-example-generic"data-slide-to="{$i-1}"class="<if  condition="$i eq 1">active</if>"></li>

</volist>

</ol>

<div class="carousel-inner">

<volist name="bopic"id="xt">

<div class='item <if condition="$i eq 1 ">active</if>'>

<img src="{$xt.page_bopic_image}"alt="{$xt.page_bopic_seo}"/>

</div>

</volist>

</div>

<a class="left carousel-control"href="#carousel-example-generic"data-slide="prev">

<span class="glyphicon glyphicon-chevron-left"></span>

</a>

<a class="right carousel-control"href="#carousel-example-generic"data-slide="next">

<span class="glyphicon glyphicon-chevron-right"></span>

</a>

</div>

<!-- /.carousel -->

</div>

 

本文介绍了PHP进程通信基础之信号量与共享内存通信,非常实用,大家可以参考一下。

由于进程之间谁先执行并不确定,这取决于内核的进程调度算法,其中比较复杂。由此有可能多进程在相同的时间内同时访问共享内存,从而造成不可预料的错误。信号量这个名字起的令人莫名其妙,但是看其英文原意,就十分容易理解。

semaphore 英[ˈseməfɔ:(r)] vt. 发出信号,打旗语;

类似于指挥官的作用。

下面我们看下一个伪代码信号量的使用。

1、创建信号量唯一标识符

$ftok = ftok(__FILE__, 'a');

2、创建信号量资源ID

$sem_resouce_id = sem_get($ftok);

3、接受信号量

sem_acqure($sem_resource_id);

4、释放信号量

sem_release($sem_resource_id);

5、销毁信号量

sem_remove($sem_resource_id);

举个不文雅的例子,使我们容易理解这个信号量在生活中的用法。理解之后可以套用到我们编程领域。
一家公司只有一个卫生间。那么当有人上厕所的时候,都要获取一把锁(信号量),表示卫生间正在使用。代码如下:

sem_acqure($sem_resource_id);

那么员工上完厕所之后,就需要将锁打开,释放锁(信号量),表示现在可以允许别人使用。代码如下:

sem_release($sem_resource_id);

通过一个简单的锁,我们就能够知道当前的厕所(共享内存)是否可以使用。这个例子不雅观,但说明了问题。这篇博客也是有味道的博客,真是不容易。。。。以下是示例代码:

 

 代码如下复制代码

<?php

//创建共享内存区域

$shm_key = ftok(__FILE__,'a');

$shm_id = shm_attach($shm_key, 1024, 0755);

 

//var_dump($shm_id);die(); resource(4) oftype(sysvshm)

const SHARE_KEY = 1;

$child_list = [];

 

//加入信号量

$sem_id = ftok(__FILE__,'b');

$signal = sem_get($sem_id);

 

//$signal resource(5) oftype(sysvsem)

 

 

for($i = 0; $i < 3; $i++) {

  $pid = pcntl_fork();

  if($pid == -1) {

    exit("Fork fail!".PHP_EOL);

  } elseif ($pid == 0) {

    //获取信号量

    sem_acquire($signal);

    if(shm_has_var($shm_id,SHARE_KEY)) {

      $count = shm_get_var($shm_id, SHARE_KEY);

      $count++;

      //模拟业务处理

      $sec = rand(1, 3);

      sleep($sec);

      shm_put_var($shm_id, SHARE_KEY, $count);

    }else{

      $count = 0;

      $sec = rand(1, 3);

      sleep($sec);

      shm_put_var($shm_id, SHARE_KEY, $count);

    }

 

    echo"child process: ".getmypid()." is writing! now count is: $count ".PHP_EOL;

 

    //释放信号量

    sem_release($signal);

    exit("child process".getmypid()."end".PHP_EOL);

  }else{

    $child_list[] = $pid;

  }

}

 

while(count($child_list) > 0) {

  foreach ($child_list as $key => $pid) {

    $status = pcntl_waitpid($pid, $status);

    if($status > 0 || $status == -1) {

      unset($child_list[$key]);

    }

  }

  sleep(1);

}

 

$count = shm_get_var($shm_id, SHARE_KEY);

echo" $count  ".PHP_EOL;

 

//销毁信号量

sem_remove($signal);

 

shm_remove($shm_id);

shm_detach($shm_id);

 

小编推荐的这篇文章介绍了PHP 信号管理知识整理汇总,非常实用,有兴趣的同学快来看看吧。

SIGQUIT    建立CORE文件终止进程,并且生成core文件
SIGILL     建立CORE文件       非法指令
SIGTRAP    建立CORE文件       跟踪自陷
SIGBUS     建立CORE文件       总线错误
SIGSEGV    建立CORE文件        段非法错误
SIGFPE     建立CORE文件       浮点异常
SIGIOT     建立CORE文件        执行I/O自陷

SIGSTOP    停止进程     非终端来的停止信号
SIGTSTP    停止进程      终端来的停止信号
SIGTTOU    停止进程     后台进程写终端
SIGTTIN    停止进程      后台进程读终端

SIGHUP     终止进程     终端线路挂断
SIGINT     终止进程     中断进程
SIGXGPU    终止进程     CPU时限超时
SIGXFSZ    终止进程     文件长度过长
SIGPROF    终止进程     统计分布图用计时器到时
SIGUSR1    终止进程      用户定义信号1
SIGUSR2    终止进程     用户定义信号2
SIGVTALRM  终止进程     虚拟计时器到时
SIGKILL    终止进程     杀死进程
SIGPIPE    终止进程      向一个没有读进程的管道写数据
SIGALARM   终止进程     计时器到时
SIGTERM    终止进程      软件终止信号

SIGCONT    忽略信号     继续执行一个停止的进程
SIGURG     忽略信号      I/O紧急信号
SIGIO      忽略信号     描述符上可以进行I/O
SIGCHLD    忽略信号      当子进程停止或退出时通知父进程
SIGWINCH   忽略信号     窗口大小发生变化

1 SIGHUP

本信号在用户终端连接(正常或非正常、结束时发出, 通常是在终端的控制进程结束时, 通知同一session内的各个作业, 这时它们与控制终端不再关联.

2、SIGINT

程序终止(interrupt、信号, 在用户键入INTR字符(通常是Ctrl-C、时发出

3、 SIGQUIT

SIGQUIT 和SIGINT类似, 但由QUIT字符(通常是Ctrl-、来控制. 进程在因收到SIGQUIT退出时会产生core文件, 在这个意义上类似于一个程序错误信 号.

4、SIGILL

SIGILL 执行了非法指令. 通常是因为可执行文件本身出现错误, 或者试图执行数据段. 堆栈溢出时也有可能产生这个信号.

5、 SIGTRAP

SIGTRAP 由断点指令或其它trap指令产生. 由debugger使用.

6、 SIGABRT

SIGABRT 程序自己发现错误并调用abort时产生.
6、 SIGIOT

SIGIOT 在PDP-11上由iot指令产生, 在其它机器上和SIGABRT一样.

7、 SIGBUS

SIGBUS 非法地址, 包括内存地址对齐(alignment、出错. eg: 访问一个四个字长的整数, 但其地址不是4的倍数.

8、 SIGFPE

SIGFPE 在发生致命的算术运算错误时发出. 不仅包括浮点运算错误, 还包括溢 出及除数为0等其它所有的算术的错误.

9、 SIGKILL

SIGKILL 用来立即结束程序的运行. 本信号不能被阻塞, 处理和忽略.

10、 SIGUSR1

SIGUSR1 留给用户使用

11、 SIGSEGV

SIGSEGV 试图访问未分配给自己的内存, 或试图往没有写权限的内存地址写数据.

12、 SIGUSR2

SIGUSR2 留给用户使用

13、 SIGPIPE

Broken pipe

14、 SIGALRM

SIGALRM 时钟定时信号, 计算的是实际的时间或时钟时间. alarm函数使用该信号.

15、SIGTERM

SIGTERM 程序结束(terminate、信号, 与SIGKILL不同的是该信号可以被阻塞和处理. 通常用来要求程序自己正常退出. shell命令

kill缺省产生这个信号.

17、 SIGCHLD

SIGCHLD 子进程结束时, 父进程会收到这个信号.

18、 SIGCONT

SIGCONT 让一个停止(stopped、的进程继续执行. 本信号不能被阻塞. 可以用一个handler来让程序在由stopped状态变为继续执行时完成特定的工作. 例如, 重新显示提示符

19、 SIGSTOP

SIGSTOP 停止(stopped、进程的执行. 注意它和terminate以及interrupt的区别: 该进程还未结束, 只是暂停执行. 本信号不能被阻塞, 处理或忽略.

20、 SIGTSTP

SIGTSTP 停止进程的运行, 但该信号可以被处理和忽略. 用户键入SUSP字符时 (通常是Ctrl-Z、发出这个信号

21、 SIGTTIN

SIGTTIN 当后台作业要从用户终端读数据时, 该作业中的所有进程会收到SIGTTIN 信号. 缺省时这些进程会停止执行.

22、 SIGTTOU

SIGTTOU 类似于SIGTTIN, 但在写终端(或修改终端模式、时收到.

23、 SIGURG

SIGURG 有”紧急”数据或out-of-band数据到达socket时产生.

24、 SIGXCPU

SIGXCPU 超过CPU时间资源限制. 这个限制可以由getrlimit/setrlimit来读取/ 改变

25、 SIGXFSZ

SIGXFSZ 超过文件大小资源限制.

26、 SIGVTALRM

SIGVTALRM 虚拟时钟信号. 类似于SIGALRM, 但是计算的是该进程占用的CPU时间.

27、 SIGPROF

SIGPROF 类似于SIGALRM/SIGVTALRM, 但包括该进程用的CPU时间以及系统调用的 时间.

28、 SIGWINCH

SIGWINCH 窗口大小改变时发出.

29、SIGIO

SIGIO 文件描述符准备就绪, 可以开始进行输入/输出操作.

30、SIGPWR

SIGPWR Power failure

有 两个信号可以停止进程:SIGTERM和SIGKILL。  SIGTERM比较友好,进程能捕捉这个信号,根据您的需要来关闭程序。在关闭程序之前,您  可以结束打开的记录文件和完成正在做的任务。在某些情况下,假 如进程正在进行作业而且不能中断,那么进程可以忽略这个SIGTERM信号。

对于SIGKILL信号,进程是不能忽略的。这是一个 “我不管您在做什么,立刻停止”的信号。假如您发送SIGKILL信号给进程,Linux就将进程停止在那里。

[!--infotagslink--]

相关文章

  • php svn操作类

    以前我们开发大型项目时都会用到svn来同步,因为开发产品的人过多,所以我们会利用软件来管理,今天发有一居然可以利用php来管理svn哦,好了看看吧。 代码如下 ...2016-11-25
  • MySQL性能监控软件Nagios的安装及配置教程

    这篇文章主要介绍了MySQL性能监控软件Nagios的安装及配置教程,这里以CentOS操作系统为环境进行演示,需要的朋友可以参考下...2015-12-14
  • 详解Mysql中的JSON系列操作函数

    新版 Mysql 中加入了对 JSON Document 的支持,可以创建 JSON 类型的字段,并有一套函数支持对JSON的查询、修改等操作,下面就实际体验一下...2016-08-23
  • C#操作config文件的具体方法

    这篇文章介绍了在C#中对config文件的操作,有需要的朋友可以参考一下...2020-06-25
  • 深入研究mysql中的varchar和limit(容易被忽略的知识)

    为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题。 ...2015-03-15
  • python自动化办公操作PPT的实现

    这篇文章主要介绍了python自动化办公操作PPT的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-05
  • MySQL 字符串拆分操作(含分隔符的字符串截取)

    这篇文章主要介绍了MySQL 字符串拆分操作(含分隔符的字符串截取),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-22
  • mysql的3种分表方案

    一、先说一下为什么要分表:当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。根据个人经验,mysql执行一个sql的过程如下:1...2014-05-31
  • Windows服务器MySQL中文乱码的解决方法

    我们自己鼓捣mysql时,总免不了会遇到这个问题:插入中文字符出现乱码,虽然这是运维先给配好的环境,但是在自己机子上玩的时候咧,总得知道个一二吧,不然以后如何优雅的吹牛B。...2015-03-15
  • nodejs文件操作模块FS(File System)常用函数简明总结

    件系统操作相关的函数挺多的。首先可以分为两大类。一类是异步+回调的。 一类是同步的。在这里只对异步的进行整理,同步的只需要在函数名称后面加上Sync即可1. 首先是一类最常规的读写函数,函数名称和形式,应该是起源于C...2014-06-07
  • Centos5.5中安装Mysql5.5过程分享

    这几天在centos下装mysql,这里记录一下安装的过程,方便以后查阅Mysql5.5.37安装需要cmake,5.6版本开始都需要cmake来编译,5.5以后的版本应该也要装这个。安装cmake复制代码 代码如下: [root@local ~]# wget http://www.cm...2015-03-15
  • 用VirtualBox构建MySQL测试环境

    宿主机使用网线的时候,客户机在Bridged Adapter模式下,使用Atheros AR8131 PCI-E Gigabit Ethernet Controller上网没问题。 宿主机使用无线的时候,客户机在Bridged Adapter模式下,使用可选项里唯一一个WIFI选项,Microsoft Virtual Wifi Miniport Adapter也无法上网,故弃之。...2013-09-19
  • C#模拟window操作鼠标的方法

    这篇文章主要介绍了C#模拟window操作鼠标的方法,可实现模拟鼠标移动到固定位置后点击右键的功能,涉及鼠标常用事件的操作技巧,需要的朋友可以参考下...2020-06-25
  • 忘记MYSQL密码的6种常用解决方法总结

    首先要声明一点,大部分情况下,修改MySQL密码是需要有mysql里的root权限的...2013-09-11
  • MySQL数据库备份还原方法

    MySQL命令行导出数据库: 1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录 如我输入的命令行:cd C:/Program Files/MySQL/MySQL Server 4.1/bin (或者直接将windows的环境变量path中添加该目录) ...2013-09-26
  • js有序数组的连接问题

    1.前言 昨天碰到一道关于如何解决有序数组的连接问题,这是一个很常见的问题。但是这里要考虑到代码的效率问题,因为要连接的数组都是有序的,这是一个非常重要的前提条件。2.简单但效率不高的算法 我首先想到的是使用...2013-10-04
  • Mysql命令大全(详细篇)

    一、连接Mysql格式: mysql -h主机地址 -u用户名 -p用户密码1、连接到本机上的MYSQL。首先打开DOS窗口,然后进入目录mysql/bin,再键入命令mysql -u root -p,回车后提示你输密码.注意用户名前可以有空格也可以没有空格,但是密...2015-11-08
  • Navicat for MySQL 11注册码\激活码汇总

    Navicat for MySQL注册码用来激活 Navicat for MySQL 软件,只要拥有 Navicat 注册码就能激活相应的 Navicat 产品。这篇文章主要介绍了Navicat for MySQL 11注册码\激活码汇总,需要的朋友可以参考下...2020-11-23
  • python中字符串最常用的十三个处理操作记录

    这篇文章主要给大家介绍了关于python中字符串最常用的13个处理操作的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-09
  • 微信小程序手势操作之单触摸点与多触摸点

    这篇文章主要介绍了微信小程序手势操作之单触摸点与多触摸点的相关资料,需要的朋友可以参考下...2017-03-13