Java基本sql_常用sql
1、mysql> select now(),curdate(),sysdate(),curtime();
以下三個等價:
select date(now());
select curdate();
select DATE_FORMAT(now(), '%Y-%m-%d');
2、DATE_ADD():
向日期添加指定的時間間隔DATE_ADD(OrderDate,INTERVAL?2?DAY)
3、to_days()
select to_days(now()); 返回一個天數(從年份0開始的天數)
4、alter
(1)給已有列添加默認值
ALTER TABLE manager.t_staff ALTER COLUMN c_first_task_no SET DEFAULT '0';
(2)添加comment
alter table fund.t_product_group modify c_type varchar(255) comment '1-暫未開放;2-熱賣中';
(3)修改列類型
alter table 表名 modify 列名 varchar(32);
(4)給當前字段加1(字符串連接)
update fund.t_product_log set c_change_date = c_change_date + 1 where c_id = '20170221C00381000000000000000005';
update fund.t_product_log set c_status = CONCAT(c_status,'1') where ?c_id = '20170221C00381000000000000000005';
5、case ?when then else end
create database mybatis;
use mybatis;
CREATE TABLE `testcase` (
`country` varchar(32) NOT NULL COMMENT '國家',
`sex` varchar(45) DEFAULT NULL COMMENT '性別',
`population` varchar(45) DEFAULT NULL COMMENT '人口'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='case 測試';
insert into mybatis.testcase values('中國','1','258');
insert into mybatis.testcase values('中國','2','5745');
insert into mybatis.testcase values('美國','1','5874');
insert into mybatis.testcase values('美國','2','8532');
insert into mybatis.testcase values('加拿大','1','745');
insert into mybatis.testcase values('加拿大','2','278');
使用case方式:
select country,
sum(case when sex='1' then population else 0 end) 男,
sum(case when sex='2' then population else 0 end) 女
from mybatis.testcase group by country;
join聯合多個select方式:
select a.country,a.population '男',b.population '女' from
(select country, population from mybatis.testcase where sex = '1') a
left join
(select ?country,population from mybatis.testcase where sex = '2') b on a.country = b.country order by country;
6、mysql正則表達式REGEXP
查找name字段中以'st'為開頭的所有數據:mysql>?SELECT?name?FROM?person_tbl?WHERE?name?REGEXP?'^st';
查找name字段中以'ok'為結尾的所有數據:mysql>?SELECT?name?FROM?person_tbl?WHERE?name?REGEXP?'ok$';
查找name字段中包含'mar'字符串的所有數據:mysql>?SELECT?name?FROM?person_tbl?WHERE?name?REGEXP?'mar';
查找name字段中以元音字符開頭或以'ok'字符串結尾的所有數據:mysql>?SELECT?name?FROM?person_tbl?WHERE?name?REGEXP?'^[aeiou]|ok$';
7、查看blob格式數據
select cast(字段名 as char) from 表名;
總結
以上是生活随笔為你收集整理的Java基本sql_常用sql的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 动物园大猩猩被发现在直立行走:姿势极其标
- 下一篇: 索尼副总裁承认:索尼E卡口系统当初没有考