分类:Php / Pear / Mysql / Node.js

Mysql:常见的运算符及使用, mysql运算符, mysql加法,mysql减法,mysql乘法,mysql除法, mysql数学函数

  算数运算符 MySQL支持大多数通用的、允许我们执行计算的的算数运算符。 “+(加法)、-(减法)、*(乘法)、/(除法,返回商)、%(除法,返回余数)”,如下例: select 1+2;//加法运算,结果为3 select 2-1;//减法运算,结果为1 select 3*2;//乘法运算,结果为6 select 6/2;//除法运算,结果为3 select 25%7;//除法运算,结果为4 select 5/0;//除法运算,结果为null,MySQL除法的除数为0是不允许的 请注意,所有涉及整数的数学运算都是用64位的精度进行计算。 用字符串表示的数字在任何可能便于计算的地方都被自动的转换为字符串。 遵循两个转换原则: 1:如果第一位是数字的字符串被用于算数运算中,那么它被转换为这个数字的值… Read More

PHP: 修改post 数组容量, 修改post变量容量, max_input_vars默认值为1000导致多表单提交失败

今天接到客服部工作人员反馈的一个客户的问题,产品是允许用户添加一个产品属性的,而每个属性是由多个表单域组成 ,这样当每添加一个属性就等于添加了n个表单域,这个客户添加的非常的多,发现在提交保存的时候总是失败,提示其中一个表单元素的索引值不存在,经测试是发现服务端接收的一些表单域丢失了一部分。 起初分析的是服务器接收的数据超出了php设置的max_post_size(其实当时已经设置了8M,足够使用了),修改了测试发现此问题仍然存在。后来将用户原来的一些添加的表单元素进行删除,再重新添加同样数据库表单域可以成功,但一旦超出一定数量的表单域就会发生丢失的情况,这个时候首先怀疑的是apache是否有类似限制接收隐藏域的指令,找了没有找到,紧接着在php中批到一个max_input_vars这个指令,意思就是说php中允许接收的最大表单域数据,到目前为止基本上是确定这个原因引起的了,奖其修改为2000,重启Apache,发现一切正常。 修改php.ini中的max_input_vars参数限制提交的表单数量 比如phpmysqladmin读取数据库表,然后写入编辑,但是数据库字段有128个,然后每个字段有11个input框,大概有1400多个input,而ax_input_vars默认值为1000. 修改php.ini里面加入max_input_vars ;;;;;;;;;;;;;;;;;;; ; Resource Limits ; ;;;;;;;;;;;;;;;;;;; max_execution_time = 30 //每个脚本的最大执行时间,以秒为单位 max_input_time = 60 //每个脚本解析请求的数据可能花费的最大时间,以秒为单位… Read More

MySQL:多表查询, 连表操作和GROUP_CONCAT函数的使用, GROUP BY结合GROUP_CONCAT, GROUP_CONCAT DISTINCT multiple columns

在开发网站的时候,数据库操作是必须,复杂的网站有时要涉及到几张表的同时操作。以下简单讲解一下多表查询和GROUP_CONCAT函数的使用。例如有三张表 jd_role:角色表,jd_role_privilege:角色权限id关联表,jd_privilege:权限表,三张表的结构如下: 1、要求查询每个角色拥有的权限: 使用left join左外连进行连表操作: 此时,就可以查询出每个角色拥有哪些权限,但是这样查询不是很符合实际开发,比如说在修改角色权限的时候,如何把一个角色的权限放入下拉选择框中,这需要把一个角色拥有的所有的权限转换成字符串或者数组,这时候可以使用GROUP_CONCAT函数: 2、以id分组,把权限名称打印成一行,用分号隔开: 3、以id分组,把权限名称打印成一行,去除重复字段: 4、以id分组,把权限名称打印成一行,用逗号隔开,根据权限id排序: 本质上就是用到了下面的样板句: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符']) 例如: select… Read More