易截截图软件、单文件、免安装、纯绿色、仅160KB

mySql中如何批量更新计数器


假如我们的mysql有一个计数器,而这个计数器需要我们重新统计,怎么办呢?
应用场景,比如说有一个商场,每卖一个产品都产生一个流水,然后我们需要知道每笔流水是该产品第几次出售的,这样说可能不明白,我拿一个详细的数据
举例吧。
recordID,productID,productType,sellDate,counter
1, 1, 1, '2010-1-15 15:20:10' 0
2, 1, 2, '2010-1-15 15:20:10' 1
3, 2, 1, '2010-1-15 15:20:10' 0
4, 2, 1, '2010-1-15 15:20:10' 1
上面这个数据是一些撒气数据,包括记录的流水号,产品的编号,产品的类型,销售的时间,计数器。一般来说,计数器我们首先我会想到自增,但这而肯定
是不可能使用自增长的。
我最初的时候,尝使用这样的代码:update t_product set t_counter = (select max(counter)
from t_product where productid = 1 and productType = 1) + 1 where where
productid = 1 and productType = 1
但是mysql报错,上网一查,mysql不支持这种写法,呵呵,我对mysql完全不熟悉。记得以前在sql
server用过游标,然后也试试查找游标,经过n次google与百度,最终搞定这个难题。
我本身对mysql完全是个外行,就连注释也不知道怎么注释的,现在终于知道有三种写法的,而--的注释后面是要空一格的,所以代码写得性能什么的
就不敢说了,只是实现了这个功能,希望对有同样需求的朋友有用。
呵,还学到一点,declare只能写在最前面。
看最终的代码:
CREATE
PROCEDURE
p_resetCounter (
)
BEGIN
DECLARE
productID INT
;
DECLARE
type
INT
;
DECLARE
tmpCount INT
;
DECLARE
stopFlag int
;
 
#使用游标
DECLARE
cur cursor for SELECT
COUNT
(
*
)
,
productID,
productType from
t_product GROUP BY
productID,
productType;
DECLARE
CONTINUE HANDLER
FOR NOT
FOUND set
stopFlag=
1
;
#如果找不到记录,则设置stopFlag=1
 
#定义变量及创建临时表
CREATE
TEMPORARY
TABLE
tmp_Counter(
recordID int
not
null
,
Counter int
not
null
)
TYPE
=
HEAP;
 
#打开游标
open cur;
REPEAT
fetch cur into
tmpCount,
productID,
type
;
SET
@id =
-
1
;
INSERT
INTO
tmp_Counter
(
SELECT
recordID,
(
@id :=
@id +
1
)
counter
from
t_prod


相关文档:

Struts+Hibernate+MySql中文乱码解决方案

1、修改MySql数据库的my.ini配置文件、
# CLIENT SECTION
# ----------------------------------------------------------------------
#
# The following options will be read by MySQL client applications.
# Note that only client applications shipped by MySQL are guaranteed
# to read this section. If yo ......

linux下c语言连接mysql数据库

在FC8中默认安装的有mysql,没有的话可以很方便的安装下。
默认的mysql的include文件目录在/usr/include/mysql
默认的mysql的lib文件夹在/usr/lib/mysql
这两个目录在我们编译时候需要到。
我的测试用的C代码为:
#include <stdio.h>
#include <stdlib.h>
#include <mysql.h>
#define CONN_HOST ......

MySQL常用命令与基本命令操作


1、MySQL常用命令 ­
­
create database name; 创建数据库 ­
­
use databasename; 选择数据库 ­
­
drop database name 直接删除数据库,不提醒 ­
­
show tables; 显示表 ­
­
describe tablename; 表的详细描述 ­
­
select 中加上distinct去除重复字段 ­ ......

MYSQL中统计查询结果总行数的便捷方法【转载】

转自:http://ginew.blog.163.com/
今天阅读 wordpress代码时,发现一个MYSQL的关键词 SQL_CALC_FOUND_ROWS 查看手册后发现此关键词的作用是在查询时统计满足过滤条件后的结果的总数(不受 Limit 的限制)
例如: SELECT SQL_CALC_FOUND_ROWS tid from cdb_threads WHERE fid=14 LIMIT 1,10;
假设满足条件的有1000条,这 ......

windows2003+iis6+php+mysql 服务器配置

在网上看了很多关于windows2003+iis6+php+mysql 服务器配置的文章,大体上都是互相抄袭,不过一些公共的信息还是很正确的,但是针对一些特别的机器或者因为个人不同的配置总不能按照文章的内容操作成功,下面说一种较为简单的操作方法,步骤如下:
1.iis安装(略)
2.下载AppServ并安装
3.在c:\建php5文件夹,然后再php5 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号