【Python】SQL to Pandas 速查表(二)

栏目: 数据库 · 发布时间: 6年前

内容简介:本篇将解构下面的本篇将解构下面的

本篇将解构下面的 SQL 查询句式, 使用 Pandas 进行实现

SQL 查询句式

SELECT DISTINCT [字段] 
FROM [表] JOIN [bin] ON [连接条件] 
WHERE [过滤条件] 
GROUP BY [字段] 
HAVING [条件] 
ORDER BY [字段] DESC 
LIMIT [个数] OFFSET [个数]
复制代码

读取评论数据

df_comments = pd.read_sql(sql="select * from comments", con=conn)
复制代码

数据预览

df_comments
复制代码
id student_id content
0 1 1 测试评论1
1 2 5 测试评论5
2 3 2 测试评论2
3 4 3 测试评论3
4 5 1 测试评论11
5 6 9 测试评论9

JOIN

(INNER) JOIN

SQL

SELECT
	* 
FROM
	student
	INNER JOIN comments ON student.id = comments.student_id;
复制代码

Pandas

pd.merge(df, df_comments, left_on='id', right_on='student_id')
复制代码

LEFT (OUTER) JOIN

SQL

SELECT
	* 
FROM
	student
	LEFT JOIN comments ON student.id = comments.student_id;
复制代码

Pandas

pd.merge(df, df_comments, left_on='id', right_on='student_id', how='left')
复制代码

RIGHT (OUTER) JOIN

SQL

SELECT
	* 
FROM
	student
	RIGHT JOIN comments ON student.id = comments.student_id;
复制代码

Pandas

pd.merge(df, df_comments, left_on='id', right_on='student_id', how='right')
复制代码

UNION

SQL

SELECT * FROM student where city ='北京' 
UNION 
SELECT * FROM student where sex ='男';
复制代码

Pandas

pd.concat([df[df.city == '北京'], df[df.sex == '男']]).drop_duplicates().reset_index()
复制代码

UNION ALL

SQL

SELECT * FROM student where city ='北京' 
UNION ALL 
SELECT * FROM student where sex ='男';
复制代码

Pandas

pd.concat([df[df.city == '北京'], df[df.sex == '男']]).reset_index()
复制代码

本篇内容

本篇将解构下面的 SQL 查询句式, 使用 Pandas 进行实现

SQL 创建句式

CREATE TABLE [表名] (
    [列名] [类型],
    [列名] [类型],
   ....
);
复制代码

SQL 插入句式

INSERT INTO [表名] VALUES ([值], [值], ...);
INSERT INTO [表名] ([列名],[列名] ...) VALUES ([值], [值], ...);
复制代码

SQL 更新句式

UPDATE [表名]
SET [列名] = [值], [列名] = [值]
WHERE [过滤条件];
复制代码

SQL 删除句式

DELETE FROM [表名] WHERE [过滤条件];
复制代码

CREATE

SQL

CREATE TABLE student (
	id INT ( 11 ) NOT NULL AUTO_INCREMENT,
	name VARCHAR ( 10 ) COLLATE utf8mb4_general_ci DEFAULT NULL,
	age date DEFAULT NULL,
	sex VARCHAR ( 10 ) COLLATE utf8mb4_general_ci DEFAULT NULL,
	city VARCHAR ( 255 ) CHARACTER 
    SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,
	money DOUBLE ( 255, 2 ) DEFAULT NULL,

);
复制代码

Pandas

pd.DataFrame(columns=['id', 'name', 'sex', 'city', 'money'])
复制代码

INSERT

SQL

INSERT INTO student (id, name, age, sex, city, money )
VALUES
	(1, '张三', '2017-12-20', '女', '天津', 20.00 );
复制代码

Pandas

# 第一种
df.loc[-1] = [1, '张三', '女', '天津', 20.00]
df.index = df.index + 1
df = df.sort_index()

# 第二种
temp_pd = pd.DataFrame({'id': [1], 'name': ['张三'], 'sex': ['女'], 'city': ['天津'], 'money': [20.00]})
df = pd.concat([df,temp_pd], ignore_index=True)
df.reset_index()

# 第三种
temp_pd = pd.DataFrame([[1,'张三1', '女', '天津', 20.00]], columns=df.columns)
df = pd.concat([df, temp_pd])
df.reset_index()
复制代码

UPDATE

SQL

UPDATE student SET money = 300 WHERE id = 1;
复制代码

Pandas

df.loc[df.id == 1, 'money'] = 300
复制代码

以上所述就是小编给大家介绍的《【Python】SQL to Pandas 速查表(二)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法数论

算法数论

裴定一、祝跃飞 / 科学出版社 / 2002年09月 / 19.00

本书论述了算法数论的基本内容,其中包括:连分数、代数数域、椭圆曲线、素性检验、大整数因子分解算法、椭圆曲线上的离散对数、超椭圆曲线。本书的特点是内容涉及面广,在有限的篇幅内,包含了必要的预备知识和数学证明,尽可能形成一个完整的体系。并且本书的部分内容曾多次在中国科学院研究生院信息安全国家重点实验室和广州大学作为硕士研究生教材使用。 本书可作为信息安全、数论等专业的研究生教材及相关专业的研究人......一起来看看 《算法数论》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具