select
目前創(chuàng)新互聯(lián)公司已為千余家的企業(yè)提供了網(wǎng)站建設、域名、虛擬主機、網(wǎng)站托管維護、企業(yè)網(wǎng)站設計、紅河哈尼網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
goods_name?產(chǎn)品名字,
max(price)?價格,
max(case?rank_name?when?'VIP1'?then?(case?when?user_price?is?null?then?discount*price/100?else?user_price?end)?end)?vip1價格,
max(case?rank_name?when?'VIP2'?then?(case?when?user_price?is?null?then?discount*price/100?else?user_price?end)?end)?vip2價格,
max(case?rank_name?when?'VIP3'?then?(case?when?user_price?is?null?then?discount*price/100?else?user_price?end)?end)?vip3價格
from?member_price?mp
left?join?goods?gd?on?gd.goods_id?=?mp.goods_id
left?join?user_rank?ur?on?ur.rank_id?=?mp.rank_id
group?by?goods_name;
mysql不是很熟悉,所以寫了個標準sql語法的。我記得mysql中group by的select可以不用跟聚合函數(shù)的,所以LZ大概可以把max()去掉,而mysql中好像有isnull,ifnull的函數(shù),我不太了解,這里用case語句替代了,LZ可以自行替換。
最好是拆開來使用,比如數(shù)據(jù)里面有1,2,3 你要查詢 1,3
就寫find_in_set('1',ids) and find_in_set('2',ids);
如果你只是查詢2
就直接 where find_in_set('2',ids);
如果是完全要相等 就直接寫等于啊,如果只是需要包含就用上面的、
insert into 表名 values(default,"名字","2011-04-15 12:22:25"); //default可以換成null
------------------------------
insert into 表名 (name,datetime) values("名字","2011-04-15 12:22:25");
使用SQL語法大寫,增加可讀性(小寫部分就是自己數(shù)據(jù)庫寫的表/字段嘍,具體你懂得...)。
創(chuàng)建數(shù)據(jù)庫:CREATE DATABASE mysql_db;
刪除數(shù)據(jù)庫:DROP DATABASE mysql_db;
查看數(shù)據(jù)庫:SHOW DATABASES;
使用數(shù)據(jù)庫:USE mysql_db;
查看數(shù)據(jù)庫中的表:SHOW TABLES;
創(chuàng)建表:
CREATE TABLE user(
id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(20) UNIQUE NOT NULL,
sex ENUM('1','2','3') NOT NULL DEFAULT 3
);
查看表結構:①SELECT COLUMN FROM user;
②DESC user;
查看表創(chuàng)建語句(可查看各種自動生成的名字):SHOW CREATE TABLE user;
插入表記錄:
①INSERT INTO user(id,username,sex) VALUES(1,'Tom',1);
②INSERT user(username) VALUES ('John');
查找表:SELECT * FROM user;
刪除表中的數(shù)據(jù)(保留表結構):TRUNCATE TABLE user;
將查詢結果寫入新表:
INSERT [INTO] privinces(sex) SELECT sex FROM user GROUP BY sex;
(若表中有數(shù)據(jù),請不要隨意更改表名、列名)
修改表名:
①ALTER TABLE user RENAME [AS|TO] users;
②RENAME TABLE user TO users;
添加單列:
ALTER TABLE user
ADD [COLUMN] age SMALLINT NOT NULL UNSIGNED DEFUALT 18
[FIRST | AFTER sex];
刪除列:ALTER TABLE user DROP sex[,DROP age];
修改列名稱和定義:
ALTER TABLE user
CHANGE [COLUMN] age a_ge TINYINT NOT NULL UNSIGNED AFTER id;
單表更新:UPDATE user SET age = age + 5,sex = 1 [WHERE id = 2];
單表刪除:DELETE FROM user [WHERE id =3];
單(多)表連接:
SELECT p.userid,p.username FROM user AS p LEFT JOIN user AS s
ON p.userid = s.age;
單(多)表刪除:
DELETE * FROM user [AS] u1 LEFT JOIN (
SELECT p.userid FROM user AS p LEFT JOIN user AS s
ON p.userid =s.age GROUP BY p.userid HAVING COUNT(s.age)1 ) [AS] u2
ON u1.userid = u2.age
WHERE u1.userid u2.userid;
查找記錄:
SELETE select_expr [,select_expr]
[
FROM table_references
[WHERE where_condition]
[GROUP BY {col_name|position}[ASC|DESC],...] //查詢結果分組
[HAVING where_condition] //設置分組條件
[ORDER BY {col_name|expr|position}[ASC|DESC]] //對結果排序
LIMIT {[offset,]row_count|row_count OFFSET offset}]//限制記錄數(shù)量
]
記錄為2、3行:SELECT * FROM user LIMIT 1,2;
別名使用(在項目中一般都使用別名)AS alias_name:
SELECT id AS uid FROM user AS u ;
子查詢:
SELECT AVG(age) FROM user WHERE userid =
[ALL|SOME|ANY|[NOT] IN|[NOT] EXISTS](SELECT uid FROM privinces WHERE pname = '河南');
外鍵約束:
(父表為user表,必須先在父表中插入數(shù)據(jù),才能在子表中插入數(shù)據(jù))
CASEADE:從父表中刪除或更新行 且 自動級聯(lián)刪除或更新子表中匹配的行;
SET NULL:從父表刪除或更新行,并設置子表中的外鍵列為NULL;
RESTRICT:拒絕對父表的更新或刪除操作;
CREATE TABLE privinces(
pid SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
pname VARCHAR(20) NOT NULL ,
uid SMALLINT,
FOREIGN KEY (uid) REFERENCES user (id) //privinces的字段uid與user表的字段id外鍵約束
ON DELETE CASEADE //刪除時 級聯(lián)刪除
);
增加主鍵、唯一、外鍵約束:
ALTER TABLE privinces
ADD [CONSTRAINT uq_pname] UNIQUE(pname);
添加/刪除默認約束:
ALTER TABLE privinces
ALTER pname {SET DEFAULT literal | DROP DEFAULT};
刪除主鍵約束:
ALTER TABLE privinces DROP PRIMARY KEY;
刪除唯一(索引)約束:
(查看約束名字key_name: SHOW INDEXS FROM privinces;)
ALTER TABLE privinces DROP {INDEX | KEY} 約束名;
刪除外鍵約束:
(查看約束名字:SHOW CREATE TABLE privinces;)
ALTER TABLE privinces DROP FOREIGN KEY 約束名;
多表更新:
UPDATE 表的參照關系 SET col_name = {[expr | value]};
表的參照關系:
tab1_reference {[INNER|CROSS] JOIN |{LEFT|RIGHT}[OUTER] JOIN} tab2_refenence ON conditional_expr;
內連接:INNER JOIN
左外連接:LEFT JOIN
右外連接:ROGHT JOIN
UPDATE user INNER JOIN privinces ON user_privince = pname
SET user_privince = pid;//(更新user內連接privince,條件是 user_privince.=pname,設置user_privince=pid)
創(chuàng)建數(shù)據(jù)表的同時將查詢結果寫入數(shù)據(jù)表:
CREATE TABLE table_name
[create_definition, ...] //創(chuàng)建語句的定義
select_statement; //要插入查詢結果的 查詢語句
字符函數(shù):
CONCAT()字符連接;CONCAT('I','LOVE','YOU');
CONCAT_WS()使用指定的分隔符進行字符連接;
CONCAT_WS('|','A','B');第一個為分割符
FORMAT();數(shù)字格式化;
FORMAT(99999.99,1);將數(shù)字格式化,并保留1位小數(shù)
LOWER();轉換成小寫字符
UPPER();轉換成大寫字符
LEFT();獲取左側字符
RIGHT();獲取右側字符
LENGTH();獲取字符長度;
LTRIN();刪除前導字符;
RTRIM();刪除后續(xù)字符
TRIM();刪除前導、后續(xù)字符;
SUBSTRING();字符串的截?。?/p>
SUBSTRING('MYSQL',1,2);從第一位中截取2位;(mysql不允許為負值)
[NOT] LIKE;模式匹配
SELECT * FROM user WHERE username LIKE '%1%%' ESCAPE '1';
REPLACE();替換字符串中的字符
REPLACE('M??Y??SQL','?','*');將M??Y??SQL中的?替換成*;
數(shù)值運算符:
CEIL();進一去整;
DIV;整數(shù)除法;
FLOOR();舍一去整;
MOD;取余數(shù)(模);
POWER();冪運算;
ROUND();四舍五入;ROUND(3.562,1);取一位小數(shù)
TRUNCATE();數(shù)字截取;TRUNCATE(125.89,1);小數(shù)后截取一位;
日期時間:
NOW();當前時間;
CURDATE();當前日期;
CURTIME();當前時間;
DATE_ADD();日期變化;
DATE_ADD('2015-6-23',INTERVAL 365 DAY);
DATEDIFF();倆日期之間的差值;
DATE_FORMAT();進行日期格式化;
SELECT DATE_FORMAT('2015-6-26','%m/%d/%Y');
分類: mysql
用存儲過程就行了,給你一個能傳參數(shù)的實例吧
drop procedure if exists employee;
delimiter $
create procedure employee(
IN acc int(20))
BEGIN
DECLARE i INT(11);
SET i = 0;
loop1: WHILE i=acc DO
你的sql語句
SET i=i+1;
END WHILE loop1;
end $
delimiter ;
call employee(1000)
mysql常用命令詳解
mysql安裝目錄
數(shù)據(jù)庫目錄
/var/lib/mysql/
配置文件
/usr/share/mysql(mysql.server命令及配置文件)
相關命令
/usr/bin(mysqladmin mysqldump等命令)
啟動腳本
/etc/init.d/mysql(啟動腳本文件mysql的目錄)
系統(tǒng)管理
連接mysql
格式:
mysql -h 主機地址 -u用戶名 -p用戶密碼
例 1:連接到本機上的 mysql。
hadoop@ubuntu:~$ mysql
-uroot -pmysql;
例 2:連接到遠程主機上的 mysql。
hadoop@ubuntu:~$ mysql -h
127.0.0.1 -uroot -pmysql;
SELECT INTO 語句
SELECT INTO 語句從一個表中選取數(shù)據(jù),然后把數(shù)據(jù)插入另一個表中。
SELECT INTO 語句常用于創(chuàng)建表的備份復件或者用于對記錄進行存檔。
SQL SELECT INTO 語法
您可以把所有的列插入新表:
SELECT *
INTO new_table_name [IN externaldatabase]
FROM old_tablename
或者只把希望的列插入新表:
SELECT column_name(s)
INTO new_table_name [IN externaldatabase]
FROM old_tablename
所以應該這么寫
SELECT?b.列1,b.列2
INTO?a
FROM?b
WHERE?id=1
---注:b表中插入a表中的列不能有a不包含的列,也就是說上面語句的b.列1,b.列2這些中不能有a中不包含的列