- 浏览: 2546600 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (676)
- linux运维 (157)
- php (65)
- mysql (78)
- nginx (27)
- apche (18)
- framework (6)
- windows (9)
- IDE工具 (23)
- struts2 (7)
- java (13)
- 移动互联网 (14)
- memcache redis (23)
- shell基础/命令/语法 (37)
- shell (50)
- puppet (4)
- C (11)
- python (9)
- 产品经理 (27)
- Sphinx (4)
- svn (12)
- 设计构建 (12)
- 项目管理 (44)
- SEO (1)
- 网站架构 (26)
- 审时度势 (42)
- 网络 (14)
- 激发事业[书&视频] (81)
- 其它 (12)
- 摄影 (8)
- android (21)
最新评论
-
zhongmin2012:
原文的书在哪里
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
renzhengzhi:
你好,请问个问题,从master同步数据到slave的时候,s ...
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
ibc789:
你好,看了你的文章,我想请教个问题, 我在用 redis的时候 ...
redis 的两种持久化方式及原理 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器
DECLARE file_path VARCHAR(100) DEFAULT '/var/lib/mysql/logs/mysqllog/';
SELECT f_get_close_sub_draws_time(0) INTO @intervalH_times;
IF(sub_draws_name < @now_sub_draws_name AND _do_today = 1,4,_status) AS status
SELECT SQL_NO_CACHE LAST_INSERT_ID() INTO @insert_id;
REPLACE INTO user_share_sum SELECT * FROM config_user_share_sum;
REPLACE INTO order_ued
(order_id, sub_draws_name, draws_date, user_id, game_id, order_time, order_amount, discount
, win_result, odds_set, `status`, time_stamp, win_flag, number, number_name, odds)
(SELECT id, sub_draws_name,DATE(order_time)+0 AS draws_date, user_id, game_id, order_time, order_amount, discount,
win_result, odds_set, `status`, NULL, win_flag, number, number_name, odds
FROM order_curr
);
===============转换为数字 -0
SET _where_orderid = CONCAT(' AND o.id= ',RIGHT(_order_id,6)-0);
======================= 转义
SET _where = CONCAT('draws_name =\'',_draws_name,'\'');
===================== 定义处理程序
格式:
DECLARE handler_type HANDLER FOR
condition_value[,...] sp_statement
handler_type:
CONTINUE | EXIT | UNDO
condition_value:
SQLSTATE [VALUE] sqlstate_value |condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION | mysql_error_code
其中,handler_type参数指明错误的处理方式,该参数有3个取值。这3个取值分别是CONTINUE、EXIT和UNDO。CONTINUE表示遇到错误不进行处理,继续向下执行;EXIT表示遇到错误后马上退出;UNDO表示遇到错误后撤回之前的操作,MySQL中暂时还不支持这种处理方式。
DROP PROCEDURE IF EXISTS `p_write_log`$$
CREATE PROCEDURE `p_write_log`(IN _file_name VARCHAR(200),OUT result_value INT)
BEGIN
DECLARE EXIT HANDLER FOR NOT FOUND
BEGIN
SET result_value = 0;
END;
DECLARE EXIT HANDLER FOR SQLWARNING
BEGIN
SET result_value = 0;
END;
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
SET result_value = 0;
END;
END$$
======================= LAST_INSERT_ID();
INSERT INTO operation_log(user_account
,sub_draws_name
,draws_date
,custom_game_id
,operation_type
,log_time
,ip)
VALUES(_user_account
,_draw_name
,_draw_date
,_game_id
,_operation_type
,NOW()
,inet_aton(_ip));
SET _last_insert_id = LAST_INSERT_ID();
======================ROW_COUNT() 返回影响的行数
UPDATE sub_draws SET init_status = 1 WHERE draws_name = _draws_name AND sub_draws_name = _sub_draws_name;
SET _query_rows = ROW_COUNT();
IF _query_rows > 0 THEN
==================== SELECT ... INTO 多个值
SELECT SQL_NO_CACHE id,sub_draws_name,draws_name,start_time,end_time,status,init_status
INTO
_sub_draws_id,_sub_draws_name,_draws_name,_start_time,_end_time,_status,_init_status
FROM sub_draws WHERE draws_name = _draws_name AND sub_draws_name = _sub_draws_name;
SELECT SQL_NO_CACHE IFNULL(order_id,0) INTO @max_deal_order_id FROM order_deal WHERE `type`=0;
==================== 格式化赋值
SET @status = _status;
SET @v_sql= CONCAT('UPDATE ',order_tb,' SET status = ?,order_amount = order_amount*IF(status<3,1,-1)
WHERE id=?;');
PREPARE stmt FROM @v_sql;
EXECUTE stmt USING
@status,@order_id;
DEALLOCATE PREPARE stmt;
==================== if elseif elseif end if
mysql> select if(tim="1","mon","aft") from t1;
IF _opt_type = 'add' THEN
...
ELSEIF _opt_type = 'upd' THEN
...
ELSEIF _opt_type = 'del' THEN
...
END IF;
IF 0=IS_NEW AND (
EXISTS(SELECT 1 FROM order_curr WHERE win_flag=-1 LIMIT 1) OR
EXISTS(SELECT 1 FROM short_covering_user WHERE win_flag=-1 LIMIT 1) OR
EXISTS(SELECT 1 FROM short_covering_corp WHERE win_flag=-1 LIMIT 1)
) THEN
SET IS_NEW = 1;
END IF;
IF EXISTS ( SELECT 1 FROM short_covering_corp WHERE sub_draws_name=_sub_draws_name AND STATUS=5 LIMIT 1) THEN
...
end if
==================== WHILE
WHILE _cate_id <= 21 DO
CALL p_serve(_cate_id,@result);
SET _cate_id=_cate_id+1;
END WHILE;
==================== on duplicate key update
假如有一张书目表,字段为id,name,count(库存)
现要插入一条新纪录,如果数据库没有这条纪录,插入
若已经存在,则更新库存。
解决方法:mysql 的 on duplicate key update 语法。
INSERT INTO draws_result
(drs_date, number1, number2, `status` )
VALUES (_drs_date, _number1, _number2, _status)
ON DUPLICATE KEY UPDATE
number1 = _number1,
number2 = _number2
`status` = _status;
INSERT INTO item_betting_sum(user_id
,game_id
,number
,item_sum)
VALUES(_member_id
,_game_id
,_number
,_order_amount
)
ON DUPLICATE KEY UPDATE
item_sum = item_sum + _order_amount;
==================== lpad rpad
字符串左右填充
lpad 函数从左边对字符串使用指定的字符进行填充。从其字面意思也可以理解,l是left的简写,pad是填充的意思,所以lpad就是从左边填充的意思。
lpad( string, padded_length, [ pad_string ] )
string 准备被填充的字符串;
padded_length 填充之后的字符串长度,也就是该函数返回的字符串长度,如果这个数量比原字符串的长度要短,lpad函数将会把字符串截取成从左到右的n个字符;
pad_string 填充字符串,是个可选参数,这个字符串是要粘贴到string的左边,如果这个参数未写,lpad函数将会在string的左边粘贴空格。
示例1:
SQL> select lpad('abcde',10,'x')
from dual;
xxxxxabcde
以0填充game_id,得到结果为3位:
SET __game_id = LPAD(_game_id,3,'0');
==================== WHILE 循环
SET _num = 1;
WHILE
_num <= 3 DO
SET _cur_odds_set = ELT(_num,'A','B','C');
IF _os_set != _cur_os_set THEN
。。。
END IF;
SET _num = _num + 1;
END WHILE;
==================== LEAVE
语句退出循环
IF _last_jump_odds = 0 THEN
LEAVE L_END;
END IF;
CREATE PROCEDURE myProc()
BEGIN
DECLARE i,j INT DEFAULT 1;
outer_loop: LOOP
SET j=1;
inner_loop: LOOP
SELECT CONCAT(i," times ", j," is ",i*j);
SET j=j+1;
IF j>12 THEN
LEAVE inner_loop;
END IF;
END LOOP inner_loop;
SET i=i+1;
IF i>12 THEN
LEAVE outer_loop;
END IF;
END LOOP outer_loop;
END$$
==================== FLOOR
(X) 返回不大于X 的最大整数值。
mysql> select FLOOR(1.23);
-> 1
mysql> select FLOOR(-1.23);
-> -2
注意返回值被变换为一个BIGINT
==================== CEILING
(X) 返回不小于X 的最小整数值。
mysql> select CEILING(1.23);
-> 2
mysql> select CEILING(-1.23);
-> -1
注意返回值被变换为一个BIGINT !
==================== ROUND
(X) 返回参数X 的四舍五入的一个整数。
mysql> select ROUND(-1.23);
-> -1
mysql> select ROUND(-1.58);
-> -2
mysql> select ROUND(1.58);
-> 2
注意返回值被变换为一个BIGINT !
==================== ROUND(X,D)
返回参数X 的四舍五入的有D 为小数的一个数字。如果D 为0 ,结果将没有小数点或小数部分。
mysql> select ROUND(1.298, 1);
-> 1.3
mysql> select ROUND(1.298, 0);
-> 1
注意返回值被变换为一个BIGINT !
==================== GROUP_CONCAT
GROUP_CONCAT()是MySQL数据库提供的一个函数,通常跟GROUPBY一起用
语法:
GROUP_CONCAT([DISTINCT] expr [,expr ...]
[ORDER BY {unsigned_integer | col_name | expr}
[ASC | DESC] [,col_name ...]]
[SEPARATOR str_val])
1.例如:
SELECT student_id, GROUP_CONCAT(courses_id) AS courses FROM student_courses WHERE student_id=2 GROUP BY student_id;
+------------+---------+
| student_id | courses |
+------------+---------+
| 2 | 3,4,5 |
+------------+---------+
2.当然分隔符还可以自定义,默认是以“,”作为分隔符,若要改为“|||”,则使用SEPARATOR来指定,例如:
SELECT student_id, GROUP_CONCAT(courses_id SEPARATOR '|||') AS courses FROM student_courses WHERE student_id=2 GROUP BY student_id;
+------------+---------+
| student_id | courses |
+------------+---------+
| 2 | 3|||4|||5
+------------+---------+
3.除此之外,还可以对这个组的值来进行排序再连接成字符串,例如按courses_id降序来排:
SELECT student_id, GROUP_CONCAT(courses_id ORDER BY courses_id DESC) AS courses FROM student_courses WHERE student_id=2 GROUP BY student_id;
+------------+---------+
| student_id | courses |
+------------+---------+
| 2 | 5,4,3
+-----------+---------+
4.需要注意的:
a.int字段的连接陷阱
当你用group_concat的时候请注意,连接起来的字段如果是int型,一定要转换成char再拼起来,
否则在你执行后(ExecuteScalar或者其它任何执行SQL返回结果的方法)返回的将不是一个逗号隔开的串,
而是byte[]。
该问题当你在SQLyog等一些工具中是体现不出来的,所以很难发现。
select group_concat(ipaddress) from t_ip 返回逗号隔开的串
select group_concat(id) from t_ip 返回byte[]
select group_concat(CAST(id as char)) from t_dep 返回逗号隔开的串
select group_concat(Convert(id , char)) from t_dep 返回逗号隔开的串
附Cast,convert的用法:
CAST(expr AS type), CONVERT(expr,type) , CONVERT(expr USING transcoding_name)
CAST() 和CONVERT() 函数可用来获取一个类型的值,并产生另一个类型的值。
这个类型 可以是以下值其中的 一个:
BINARY[(N)]
CHAR[(N)]
DATE
DATETIME
DECIMAL
SIGNED [INTEGER]
TIME
UNSIGNED [INTEGER]
b.长度陷阱
用了group_concat后,select里如果使用了limit是不起作用的.
用group_concat连接字段的时候是有长度限制的,并不是有多少连多少。但你可以设置一下。
使用group_concat_max_len系统变量,你可以设置允许的最大长度。
程序中进行这项操作的语法如下,其中 val 是一个无符号整数:
SET [SESSION | GLOBAL] group_concat_max_len = val;
若已经设置了最大长度,则结果被截至这个最大长度。
在SQLyog中执行 SET GLOBAL group_concat_max_len = 10 后,重新打开SQLyog,设置就会生效。
==================== insert 和 INSERT IGNORE
#select表数据插入到另一个表
INSERT tmp_gamedata(user_id,sort_flag)
(
SELECT user_id,IF(leaf_user=user_id,IF(4=level,1,2),1) AS sort_flag
FROM tmp_orderwinloss
GROUP BY user_id,sort_flag
);
NSERT IGNORE会忽略数据库中已经存在 的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据。这样就可以保留数据库中已经存在数据,达到在间隙中插入数据的目的。
INSERT IGNORE
INTO re_user(user_id,game_id,number)
(SELECT user_id,@game_id,@number FROM share_sum WHERE member_id = @member_id AND `level` <> 5
);
==================== IF ELSEIF ELSE END IF
IF 'B' = LEFT(_order_id,1) THEN
...
ELSEIF 'Y' = LEFT(_order_id,1) THEN
...
ELSE
...
END IF;
==================== CONVERT
SELECT sss_set,CONVERT(game_id,CHAR
) AS game_id,number
==================== CASE
第一种是CASE 后面不带表达式的;
CASE WHEN expression THEN 操作1
WHEN expression THEN 操作2
.......
ELSE 操作n
END
第二种是CASE 后面带表达式的(而此时WHEN 后面的则是该表达式可能的值)
通用。
CASE expression
WHEN expression值1 THEN 操作1
WHEN expression值2 THEN 操作2
.......
ELSE 操作n
END
SELECT od.order_id,od.win_flag ,(CASE od.win_flag WHEN
0 THEN 0 WHEN
1 THEN od.odds ELSE
1 END) AS d_odds
mysql> select case
tim
-> when "1" then "mon"
-> when "2" then "aft"
-> end
-> as tim
-> from t1;
====================字符串截取函数:left(), right(), substring(), substring_index()。还有 mid(), substr()
1. 字符串截取:left(str, length)
mysql> select left('sqlstudy.com', 3);
+-------------------------+
| left('sqlstudy.com', 3) |
+-------------------------+
| sql |
+-------------------------+
2. 字符串截取:right(str, length)
mysql> select right('sqlstudy.com', 3);
+--------------------------+
| right('sqlstudy.com', 3) |
+--------------------------+
| com |
+--------------------------+
3. 字符串截取:substring(str, pos); substring(str, pos, len)
3.1 从字符串的第 4 个字符位置开始取,直到结束。
mysql> select substring('sqlstudy.com', 4);
+------------------------------+
| substring('sqlstudy.com', 4) |
+------------------------------+
| study.com |
+------------------------------+
3.2 从字符串的第 4 个字符位置开始取,只取 2 个字符。
mysql> select substring('sqlstudy.com', 4, 2);
+---------------------------------+
| substring('sqlstudy.com', 4, 2) |
+---------------------------------+
| st |
+---------------------------------+
3.3 从字符串的第 4 个字符位置(倒数)开始取,直到结束。
mysql> select substring('sqlstudy.com', -4);
+-------------------------------+
| substring('sqlstudy.com', -4) |
+-------------------------------+
| .com |
+-------------------------------+
3.4 从字符串的第 4 个字符位置(倒数)开始取,只取 2 个字符。
mysql> select substring('sqlstudy.com', -4, 2);
+----------------------------------+
| substring('sqlstudy.com', -4, 2) |
+----------------------------------+
| .c |
+----------------------------------+
我们注意到在函数 substring(str,pos, len)中, pos 可以是负值,但 len 不能取负值。
4. 字符串截取:substring_index(str,delim,count)
4.1 截取第二个 '.' 之前的所有字符。
mysql> select substring_index('www.sqlstudy.com.cn', '.', 2);
+------------------------------------------------+
| substring_index('www.sqlstudy.com.cn', '.', 2) |
+------------------------------------------------+
| www.sqlstudy |
+------------------------------------------------+
4.2 截取第二个 '.' (倒数)之后的所有字符。
mysql> select substring_index('www.sqlstudy.com.cn', '.', -2);
+-------------------------------------------------+
| substring_index('www.sqlstudy.com.cn', '.', -2) |
+-------------------------------------------------+
| com.cn |
+-------------------------------------------------+
4.3 如果在字符串中找不到 delim 参数指定的值,就返回整个字符串
mysql> select substring_index('www.sqlstudy.com.cn', '.coc', 1);
+---------------------------------------------------+
| substring_index('www.sqlstudy.com.cn', '.coc', 1) |
+---------------------------------------------------+
| www.sqlstudy.com.cn |
+---------------------------------------------------+
==================== SQL_NO_CACHE和SQL_CACHE
SQL_NO_CACHE select 禁止缓存
SELECT语句中指定查询缓存的选项,对于那些肯定要实时的从表中获取数据的查询,或者对于那些一天只执行一次的查询,我们都可以指定不进行查询缓存,使用SQL_NO_CACHE 选项。
对于那些变化不频繁的表,查询操作很固定,我们可以将该查询操作缓存起来,这样每次执行的时候不实际访问表和执行查询,只是从缓存获得结果,可以有效地改善查询的性能,使用SQL_CACHE 选项。
mysql> select sql_no_cache
id,name from test3 whereid < 2;
mysql> select sql_cache
id,name from test3 where id< 2;
==================== IFNULL 和 IF
IFNULL(expr1,expr2)
如果expr1不是NULL,IFNULL()返回expr1
,否则它返回expr2。IFNULL()返回一个数字或字符串值,取决于它被使用的上下文环境。
mysql> select IFNULL(1,0);
-> 1
mysql> select IFNULL(0,10);
-> 0
mysql> select IFNULL(1/0,10);
-> 10
mysql> select IFNULL(1/0,yes);
-> yes
IF(exPR1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。
mysql> SELECT IF(1>2,2,3);
-> 3
mysql> SELECT IF(1<2,yes ,no);
-> yes
mysql> SELECT IF(STRCMP(test,test1),no,yes);
-> no
IF(1=sort_flag,IFNULL(su.user_name,\'\')
,su.mem_name) AS parent_name
UPDATE latest SET ods = IF( ods - jp_ods < _min_limit,_min_limit,ods - jp_ods) WHERE ods_set = _ods_set
SET _ods_new = IF(change_ods_a < _min_limit,_min_limit,change_ods_a);
IF EXISTS(
SELECT 1
FROM ds WHERE status < 3 AND ds_name < CURDATE())
THEN
UPDATE ds SET status = 3 WHERE status < 3 AND ds_name < CURDATE();
END IF;
==================== declare 定义变量,set 为变量赋值,@同时定义和赋值
DECLARE v_index INT;
SET v_index = 0;
SET @v_sql ="..."
直接调用存储过程函数
SET _test_a = f_get_latest(_set,_game_id,_number);
==================== union 和union all
多表联合字段数必须一致,否则会提示:
The used SELECT statements have a different number of columns
CREATE TABLE `a` (
`id` int(11) NOT NULL DEFAULT '0',
`a` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
"id" "a"
"1" "1"
"2" "2"
CREATE TABLE `b` (
`id` int(1) NOT NULL DEFAULT '0',
`b` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
"id" "b"
"1" "111"
"2" "2222"
>SELECT * FROM a UNION SELECT * FROM b;
"id" "a"
"1" "1"
"2" "2"
"1" "111"
"2" "222"
UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果 。实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION
这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。
而UNION ALL只是简单的将两个结果合并后就返回 。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。
从效率上说,UNION ALL 要比UNION快很多 ,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL
==================== distinct
select distinct name,age from student;
如果只查询一个列的话,是可以查询得到不重复的记录,但是如果要查询多列的话,就会出错,
但只要在select distinct a,b from TABLE group by a order by b 就可以实现不重复的列的查找了.
==================== concat
使用方法:
CONCAT(str1,str2,…)
select concat('11','22','33')。
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。
注意:
如果所有参数均为非二进制字符串,则结果为非二进制字符串。
如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。
一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如:
SELECT CONCAT(CAST(int_col AS CHAR), char_col)
MySQL的concat函数可以连接一个或者多个字符串,如
mysql> select concat('10');
+--------------+
| concat('10') |
+--------------+
| 10 |
+--------------+
1 row in set (0.00 sec)
mysql> select concat('11','22','33');
+------------------------+
| concat('11','22','33') |
+------------------------+
| 112233 |
+------------------------+
1 row in set (0.00 sec)
MySQL的concat函数在连接字符串的时候,只要其中一个是NULL,那么将返回NULL
mysql> select concat('11','22',null);
+------------------------+
| concat('11','22',null) |
+------------------------+
| NULL |
+------------------------+
1 row in set (0.00 sec)
#拼接可变的库名
SET @today_count = CONCAT('SELECT * AS order_counts FROM ',_db_name );
#截取后确保为数值
CONCAT(' AND o.id= ',RIGHT(_order_id,6)-0 );
==================== ELT(N,str1,str2,str3,...)
如果N= 1,返回str1,如果N= 2,返回str2,等等。如果N小于1或大于参数个数,返回NULL。ELT()是FIELD()反运算。
mysql> select ELT(1, 'ej', 'Heja', 'hej', 'foo');
-> 'ej'
mysql> select ELT(4, 'ej', 'Heja', 'hej', 'foo');
-> 'foo'
==================== FIELD(str,str1,str2,str3,...)
返回str在str1, str2, str3, ...清单的索引。如果str没找到,返回0。FIELD()是ELT()反运算。
mysql> select FIELD('ej', 'Hej', 'ej', 'Heja', 'hej', 'foo');
-> 2
mysql> select FIELD('fo', 'Hej', 'ej', 'Heja', 'hej', 'foo');
-> 0
发表评论
-
mysql表修复
2015-04-07 10:16 102961.1命令myisamchk(必须停掉mysql服务,或者所操 ... -
Table_locks_immediate
2014-08-25 15:46 3097Table_locks_immediate表示立即释放表锁数 ... -
mysql分区
2014-02-21 10:38 1858mysql自5.1开始支持分区 ... -
InnoDB 引擎独立表空间 innodb_file_per_table
2013-02-25 11:14 1320http://deeplyloving.iteye.com ... -
mysql监测工具tuning-primer.sh
2013-01-21 17:57 2664【转】http://www.dbasky.net ... -
mysql主从日志的定期清理
2013-01-21 16:24 1160[转]http://wangwei007.blog.51 ... -
[转]Mysql报错:Result consisted of more than one row
2013-01-09 16:25 15909Error Code : 1172 Result consi ... -
根据bin log 分析管理员被莫名删除问题
2013-01-04 17:04 1177============== 根据bin log 分析管理 ... -
mysql中select * for update锁表的问题
2013-01-04 14:07 2517先前介绍过SELECT ... FOR UPDATE的用法 ... -
PDO报错:Cannot execute queries while other unbuffered queries are active.
2012-12-12 17:57 11975用 PDOStatement->execute() 执行 ... -
MySQL死锁导致无法查询
2012-12-11 14:51 2570客服反馈后台无法查询,原因大概知道,是因为MySQL的事务 ... -
mysql性能分析:mysql profiling 应用
2012-12-11 10:26 13571)先打开profiling ==> set pro ... -
mysql体系结构和查看当前的数据库请求
2012-12-07 15:00 2896mysql体系结构: 由 ... -
mysql_error:Error starting thread: Resource temporarily unavailable
2012-11-01 17:57 2118121031 18:53:17 InnoDB: Unable ... -
导出bin log时间段脚本datarecover.sh
2012-09-06 13:34 1252修改 _binlogdir='/data/mysql/m ... -
Mysql备份工具xtraback全量和增量测试
2012-08-17 14:58 3872【转载】http://blog.chinaunix.net/s ... -
数据库中的隔离级别和锁机制
2012-08-09 17:55 1591ANSI/ISO SQL92标准定义了 ... -
mysqldump和mysql命令
2012-08-03 13:44 1387========================= mys ... -
【汇总】mysql join
2012-07-18 11:35 1177标准SQL中CROSS JOIN交叉连接(笛卡尔积)和内连接I ... -
mysql cursor游标的使用,实例
2012-07-17 23:09 1826mysql被oracle收购后,从mysql-5.5开始, ...
相关推荐
MySQL内部函数是数据库管理系统中非常重要的组成部分,它们用于执行各种数据处理任务,包括但不限于计算、比较、转换和处理日期时间等。以下是对标题和描述中提及的一些关键知识点的详细解释: 1. **操作符和操作符...
为了更好地学习MySQL,可以参考相关的教程和最佳实践,比如《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》和《MySQL数据库锁相关技巧汇总》等,这些...
7.4在MySQL内部存储代码276 7.4.1存储过程和函数278 7.4.2触发器279 7.4.3事件281 7.4.4在存储程序中保留注释283 7.5游标283 7.6绑定变量284 7.6.1绑定变量的优化286 7.6.2SQL接口的绑定变量286 7.6.3绑定...
`COUNT()`函数是MySQL中最常用的聚合函数之一,用于计算满足指定条件的行数。它可以接受单个列名或星号(`*`)作为参数。当参数为星号时,表示计算所有行的数量,而当参数为某个具体的列时,则表示计算该列非空值的...
- **MySQL如何使用索引**:讲解MySQL内部如何利用索引来优化查询速度。 ##### 第6章 锁机制和事务控制 - **如何加锁**:介绍不同类型的锁及其加锁方法。 - **死锁**:讨论死锁产生的原因及其解决策略。 - **事务...
这份"MySQL查询语句汇总.zip"文件包含的PDF文档很可能是对MySQL查询语法的详细概述,是学习和交流数据库知识的重要资源。这里我们将深入探讨MySQL查询语句的一些核心概念和常用操作。 1. **SELECT语句**:这是最...
这些函数常与GROUP BY语句一起使用,对分组后的数据进行汇总。 4. **GROUP BY**:GROUP BY语句用于根据一个或多个列对结果集进行分组,常与聚合函数配合,对每个组执行统计操作。 5. **HAVING**:HAVING是用于过滤...
这份“MySQL数据库精华汇总”文档提供了关于MySQL的一些核心概念和常用操作,涵盖了从数据库创建、数据操作到查询和优化等多个方面。 首先,数据库是数据的逻辑组织形式,类似于计算机文件系统中的树结构。在MySQL...
学会使用WHERE子句、聚合函数(如COUNT、SUM、AVG等)以及GROUP BY和HAVING子句来过滤和汇总数据。 4. 更新与删除数据:`UPDATE`语句用于修改现有数据,而`DELETE FROM`则用于删除数据。注意,这两个操作不加条件...
3. MySQL 的内部构造:MySQL 的内部构造可以分为两部分:服务器层和存储引擎层。 4. SQL 语句的执行顺序:SQL 语句的执行顺序是:解析、优化、执行。 5. 触发器、函数、视图、存储过程的描述:触发器是指自动执行的...
11.3 访问控制机制的内部工作原理 11.4 访问权限的设置工具 11.5 MySQL 4.1版本开始的安全密码验证 11.6 建立连接的问题 11.7 系统安全性 第12章 GIS函数 12.1 GIS数据格式 12.2 MySQL的GIS实现 ...
- 聚合函数:如`COUNT()`、`SUM()`、`AVG()`、`MAX()`、`MIN()`等,用于计算汇总信息。 4. **第4章:数据查询入门** - 复杂查询:学习如何使用`WHERE`子句进行多条件查询。 - 范围查询:理解`BETWEEN`、`IN`、`...
- **分组和汇总**:了解如何使用`GROUP BY`子句将数据分组,并结合`HAVING`子句进行组级筛选。 - **窗口函数**:掌握窗口函数的使用,如`ROW_NUMBER()`、`RANK()`和`DENSE_RANK()`等,用于处理滑动窗口、累积计算和...
内容概要:本训练材料提供了50个MySQL SQL编程的实际操作练习题,涵盖了数据库表的基本操作(创建、插入、更新、删除),以及复杂查询操作(如聚合函数的应用、子查询使用、连接条件设置等)。每一个练习题目都有...
4. **子查询与嵌套查询**:子查询是在一个查询内部嵌套另一个查询,用于解决更复杂的逻辑问题。学习如何正确使用子查询,可以提升SQL的灵活性。 5. **排序与分页**:ORDER BY用于排序结果集,LIMIT和OFFSET则用于...
这个函数对于数据报告、汇总和数据分析非常有用。下面我们将详细探讨`GROUP_CONCAT`的使用方式和相关特性。 ### 1. `GROUP_CONCAT`的基本语法 `GROUP_CONCAT`函数的基本语法如下: ```sql GROUP_CONCAT([DISTINCT...
4. **Key分区**:实质上是Hash分区的一种特殊形式,使用MySQL内部生成的哈希函数进行分区。 #### 三、分区限制与注意事项 - 在使用分区时,如果表具有主键或唯一键,则这些键必须包含分区键。这意味着分区键通常是...