代碼如下:
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、網(wǎng)站空間、營銷軟件、網(wǎng)站建設(shè)、湘西土家族網(wǎng)站維護(hù)、網(wǎng)站推廣。
//?加
sql.executeUpdate("update?classroom?set?seats='"?+?(cb.getSeats()?+?1)?+?"'?where?cno="+cb.getCno());
//?減
sql.executeUpdate("update?classroom?set?seats='"?+?(cb.getSeats()?-?1)?+?"'?where?cno="+cb.getCno());
如果是mysql5.7版本以下的,這個(gè)字段的值在mysql里面就是個(gè)字符串,純粹的sql語句是不行的,只能把這個(gè)字段的值拿出來格式化變成json對(duì)象,然后更改值,再放進(jìn)去;
如果是mysql5.7的話,可以通過新增的json_set函數(shù),來修改json字段的值,希望對(duì)你有幫助
最簡單的方法,把日期轉(zhuǎn)為時(shí)間戳, 直接使用mysql中的 unix_timestamp("時(shí)間或者列")函數(shù)
調(diào)用mysql的date_add()函數(shù)
date 參數(shù)是合法的日期表達(dá)式。expr 參數(shù)是您希望添加的時(shí)間間隔。
調(diào)用mysql date_sub()函數(shù),方法同上
1. MySQL 為日期增加一個(gè)時(shí)間間636f7079e79fa5e9819331333361306361隔:date_add()
set @dt = now();
select date_add(@dt, interval 1 day); - 加1天
select date_add(@dt, interval 1 hour); -加1小時(shí)
select date_add(@dt, interval 1 minute); - 加1分鐘
select date_add(@dt, interval 1 second); -加1秒
select date_add(@dt, interval 1 microsecond);-加1毫秒
select date_add(@dt, interval 1 week);-加1周
select date_add(@dt, interval 1 month);-加1月
select date_add(@dt, interval 1 quarter);-加1季
select date_add(@dt, interval 1 year);-加1年
MySQL adddate(), addtime()函數(shù),可以用date_add() 來替代。
下面是date_add() 實(shí)現(xiàn)addtime() 功能示例:
mysql set @dt = '2009-09-09 12:12:33';
mysql
mysql select date_add(@dt, interval '01:15:30' hour_second);-加上1小時(shí)15分30秒
date_add(@dt, interval '01:15:30' hour_second)
結(jié)果:2009-09-09 13:28:03
mysql select date_add(@dt, interval '1 01:15:30' day_second);-加1天1小時(shí)15分30秒
date_add(@dt, interval '1 01:15:30' day_second)
2008-08-10 13:28:03
date_add()函數(shù),分別為@dt 增加了“1小時(shí)15分30秒”和“1天1小時(shí)15分30秒”
2. MySQL 為日期減去一個(gè)時(shí)間間隔:date_sub()
mysql select date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second);
date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second)
MySQL date_sub() 日期時(shí)間函數(shù) 和date_add() 用法一致。
另外,MySQL 中還有兩個(gè)函數(shù)subdate(),subtime(),建議,用date_sub()來替代。
3. MySQL 另類日期函數(shù):period_add(P,N), period_diff(P1,P2)
函數(shù)參數(shù)“P”的格式為YYYYMM或者YYMM,第二個(gè)參數(shù)N表示增加或減去N month(月)。
MySQL period_add(P,N):日期加/減去N月。
mysql select period_add(200808,2), period_add(20080808,-2)
| period_add(200808,2) | period_add(20080808,-2) |
結(jié)果|200810 | 20080806 |
MySQL period_diff(P1,P2):日期P1-P2,返回N 個(gè)月。
mysql select period_diff(200808, 200801);
period_diff(200808, 200801)
結(jié)果:7
MySQL中,這兩個(gè)日期函數(shù),一般情況下很少用到。
4. MySQL日期、時(shí)間相減函數(shù):datediff(date1,date2), timediff(time1,time2)
MySQL datediff(date1,date2):兩個(gè)日期相減date1 date2,返回天數(shù)。
select datediff('2008-08-08', '2008-08-01'); - 7
select datediff('2008-08-01', '2008-08-08'); -7
MySQL timediff(time1,time2):兩個(gè)日期相減time1 time2,返回time差值。
select timediff('2008-08-08 08:08:08', '2008-08-08 00:00:00');- 08:08:08
select timediff('08:08:08', '00:00:00'); - 08:08:08
注意:timediff(time1,time2) 函數(shù)的兩個(gè)參數(shù)類型必須相同。
可以通過SELECT DATEADD(day, 相差天數(shù), 日期) AS 別名 的格式來計(jì)算上周SELECT DATEADD(day, -7, 日期) AS 別名上月SELECT DATEADD(month, -1, 日期) AS 別名上年SELECT DATEADD(year, -1, 日期) AS 別名
update語句可以搞定,但是需要join配合,
例如,有個(gè)表如下,需要將id =999對(duì)應(yīng)的name改為id=1000對(duì)應(yīng)的name
可以這么做:
1
update person t1 join (select id,name from person where id = 1000 limit 1 ) as t2 on t1.id = t2.id set t1.name = t2.name where t1.id = 999 and t2.id = 1000
修改后的結(jié)果
這樣就可以了。。