$start_time = microtime(true); $end_time = microtime(true); number_format($time_difference,3)
每日归档: 2019年11月19日
php插入数组保留换行格式到mysql
'api_response'=>var_export($this->response_json, true),
mysql 检查表是否存在
//check back table exists $back_db = $this->_cust_bak_db; $table = 'voucher_'.date('Ym',strtotime($month)); $sql = "select count(*) as cnt from `INFORMATION_SCHEMA`.`TABLES` where `TABLE_SCHEMA`='$back_db' and `TABLE_NAME`='$table'";
mysql 运算符 ,:=,@,@@
1、<=>
安全比较运算符,用来做 NULL 值的关系运算。
因为 mysql 的 NULL 值的特性,任何值和其比较的结果都是 NULL, 1 = NULL,1 <> NULL / 1 != NULL 得到的结果都是 NULL。
SELECT 1 = NULL, 1 <> NULL, 1 != NULL; +----------+-----------+-----------+ | 1 = NULL | 1 <> NULL | 1 != NULL | +----------+-----------+-----------+ | NULL | NULL | NULL | +----------+-----------+-----------+ 1 row in set (0.00 sec)
当然我们可以用 IS NULL 去判断,即
SELECT 1 IS NULL, 1 IS NOT NULL, NOT (1 IS NULL), !(1 IS NULL); +-----------+---------------+-----------------+--------------+ | 1 IS NULL | 1 IS NOT NULL | NOT (1 IS NULL) | !(1 IS NULL) | +-----------+---------------+-----------------+--------------+ | 0 | 1 | 1 | 1 | +-----------+---------------+-----------------+--------------+ 1 row in set (0.00 sec)
但用 <=> 更为简洁
SELECT 1 <=> NULL, !(1 <=> NULL); +------------+---------------+ | 1 <=> NULL | !(1 <=> NULL) | +------------+---------------+ | 0 | 1 | +------------+---------------+ 1 row in set (0.00 sec)
2、:=
:= 和 = 运算符在大部分场景下并无区别,但 := 更为全场景些。
= 只有在 set 和update时才是和 := 一样,赋值的作用,其它都是关系运算符 等于 的作用。
:= 不只在 set 和 update 时赋值的作用,在 select 也是赋值的作用。
SET @name = 'big_cat';
SELECT @name;
# = 在 select 语句中成为了比较运算符 结果为 NULL (@name 为 NULL, 在 mysql 中 NULL 和任何值比较都为 NULL)
# := 则为仍未赋值,@name_defined 被赋值为 big_cat 后再 select 就出来了
SELECT @name = 'big_cat', @name_defined := 'big_cat', @name_defined; +-------------------+----------------------------+---------------+ | @name = 'big_cat' | @name_defined := 'big_cat' | @name_defined | +-------------------+----------------------------+---------------+ | NULL | big_cat | big_cat | +-------------------+----------------------------+---------------+ 1 row in set (0.00 sec)
3、@ 用户变量
@用来标识用户变量
SET @name = "big_cat";
SELECT 'big_cat' INTO @name;
SELECT @name := 'big_cat';
4、@@系统变量
系统变量又分为全局系统变量和会话系统变量
读取系统变量
SELECT @@global.sort_buffer_size;
SELECT @@session.sort_buffer_size;
SHOW GLOBAL VARIABLES LIKE 'sort_buffer_size';
SHOW SESSION VARIABLES LIKE 'sort_buffer_size';
设置系统变量
SET @@global.sort_buffer_size = 2 * 1024 * 1024;
SET @@session.sort_buffer_size = 2 * 1024 * 1024;
SET GLOBAL sort_buffer_size = 2 * 1024 * 1024;
SET SESSION sort_buffer_size = 2 * 1024 * 1024;
有些系统变量只有全局级的,比如 max_connnections,读取时可以不显示声明 global,但设置时需要,否则会提示你设置的为全局变量。
mysql设置数据库编码
show variables where Variable_name like '%collation%' select @@character_set_database alter database vms_wisma character set utf8; alter database vms_wisma character set latin1;