MySQL中各种select指令

CREATE DATABASE lianxi CHARSET utf8;
#创建一个名为stu的表格 表头为id  有三列分别为 sname sage ssex
CREATE TABLE stu (
	id INT PRIMARY KEY AUTO_INCREMENT NOT NULL,
	sname VARCHAR(32) UNIQUE,
	sage INT,
	ssex BOOL
)

#查看表格
SELECT * FROM stu;

#往表格中插入内容
INSERT INTO stu (sname,sage,ssex) VALUE('czh',24,1),('xkm',23,0);
INSERT INTO stu (sname,sage,ssex) VALUE('xyz',17,1),('abc',20,1);
INSERT INTO stu (sname,sage,ssex) VALUE('jj',22,1),('kg',13,0);

#单独查看表格指定列名的内容
SELECT sname FROM stu;
#可以进行起别名
#起别名不会影响到表格原列名
SELECT sname AS sn FROM stu;
#可以同时指定多个列名,也支持起别名(多个列名之间用逗号隔开)
SELECT sname AS '姓名',ssex AS '性别' FROM stu;
#指定列名查看内容还可以给表起别名,用表的别名.查询列名
SELECT s.sname FROM stu AS s;



#指定列名查找内容后如何对内容进行筛选?
#挑选列表中年龄大于18的人
SELECT * FROM stu WHERE sage >18;
#挑选列表中年龄大于18的男生
SELECT * FROM stu WHERE sage >18 AND ssex=1;
#挑选列表中名字以c开头的人/结尾的人
SELECT * FROM stu WHERE sname LIKE 'c%';
SELECT * FROM stu WHERE sname LIKE '%c';
#挑选列表中不是男生的人
SELECT * FROM stu WHERE ssex <> 1;
#挑选id在(1,2,4,7)元组中的人
SELECT * FROM stu WHERE id IN (1,2,4,7);
#挑选id在2和4之间的人(包括2和4)
SELECT * FROM stu WHERE id BETWEEN 2 AND 4;
#查找id为1 2 5 的人
SELECT * FROM stu WHERE id IN (1,2,5);
#查询性别不为空的人
SELECT * FROM stu WHERE ssex IS NOT NULL;
#按年龄升序排序
SELECT * FROM stu ORDER BY sage;
#按年龄降序排序
SELECT * FROM stu ORDER BY sage DESC;

#统计求和
#求列表的个数
SELECT COUNT(*) FROM stu;

#求最大值,最小值,平均值,求和
SELECT MAX(sage) FROM stu;
SELECT MIN(sage) FROM stu;
SELECT AVG(sage) FROM stu;
SELECT SUM(s_ge) FROM stu;
#求id大于3 并且为男生的平均年龄
SELECT AVG(sage) FROM stu WHERE id>3 AND ssex=1;


#根据年龄分组
SELECT sage FROM stu GROUP BY sage;
#按照年龄进行分组划分
SELECT sage,GROUP_CONCAT(sname) AS '姓名' FROM stu GROUP BY sage;
 
#分页
LIMIT 第一个 参数+1 指的是按条件取出的内容的序号   第二个参数是指取几行
SELECT * FROM stu WHERE ssex=1 LIMIT 1,2;

CREATE TABLE person (
	id INT PRIMARY KEY AUTO_INCREMENT NOT NULL,
	pname VARCHAR(32) UNIQUE,
	page INT
)

CREATE TABLE goods (
	id INT PRIMARY KEY AUTO_INCREMENT NOT NULL,
	gname VARCHAR(32) UNIQUE,
	gprice INT,
	g_p_user_id INT
)


#两部分获取  先获取想要的id  然后根据id来查询另一个表中对应的结果
SELECT * FROM goods WHERE g_p_user_id=(SELECT id FROM person WHERE pname='盖伦');
#计算买装备总共花多少钱
SELECT SUM(gprice) FROM goods WHERE g_p_user_id=(SELECT id FROM person WHERE pname='盖伦');
#两表交集
SELECT * FROM goods INNER JOIN person ON goods.g_p_user_id=person.id;
#左表连接
SELECT * FROM goods LEFT JOIN person ON goods.g_p_user_id=person.id;
#右表连接
SELECT * FROM goods RIGHT JOIN person ON goods.g_p_user_id=person.id;

#两表交集
SELECT * FROM goods,person WHERE goods.g_p_user_id=person.id;

#笛卡尔积:不推荐使用,类似全排列 垃圾数据太多
SELECT * FROM goods,person;

SELECT * FROM stu;
#对年龄进行分组
SELECT sage AS '年龄' FROM stu GROUP BY sage;
#group by 后不能跟 where条件语句(用having替代 效果相同)
SELECT * FROM stu GROUP BY sage HAVING ssex=0;


SELECT g_p_user_id AS a FROM goods GROUP BY a;
#分组后两表的结合
SELECT * FROM person WHERE id IN (SELECT g_p_user_id AS a FROM goods GROUP BY a);


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 创建数据库命令:CREATE DATABASE database_name; 创建一个名为database_name的数据库。 2. 切换数据库命令:USE database_name; 切换到已存在的名为database_name的数据库。 3. 查看所有数据库命令:SHOW DATABASES; 列出所有已经创建过的数据库。 4. 创建表命令:CREATE TABLE table_name ( column1 datatype constraint, column2 datatype constraint, ... ); 创建一个名为table_name的表,可以添加多个列名和数据类型。 5. 查看所有表命令:SHOW TABLES; 列出当前数据库的所有表。 6. 查看表结构命令:DESCRIBE table_name; 列出表的详细结构,包括列名、数据类型、主键等。 7. 插入数据命令:INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); 向指定的table_name表插入数据。 8. 查找数据命令:SELECT column1, column2, ... FROM table_name WHERE condition; 根据条件查找指定的表的数据。 9. 更新数据命令:UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition; 在指定的表根据条件更新对应的数据。 10. 删除数据命令:DELETE FROM table_name WHERE condition; 在指定的表根据条件删除对应的数据。 11. 创建主键命令:ALTER TABLE table_name ADD PRIMARY KEY (column_name); 将指定的列名添加为该表的主键。 12. 创建外键命令:ALTER TABLE table_name ADD FOREIGN KEY (column_name) REFERENCES referenced_table_name (referenced_column_name); 将指定的列名添加为该表的外键,并将其关联到referenced_table_name表的referenced_column_name列名。 13. 创建索引命令:CREATE INDEX index_name ON table_name (column_name); 为指定的列名创建一个索引,以加快查询速度。 14. 删除表命令:DROP TABLE table_name; 删除指定表名的表,并且连带着删除与之关联的所有数据。 15. 删除数据库命令:DROP DATABASE database_name; 删除指定数据库名的数据库,并且连带着删除其的所有表和数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值