一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用

这篇具有很好参考价值的文章主要介绍了一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用

 1.SQL的概述

SQL的全称:Structured Query Language,结构化查询语言,用于访问和处理数据库的标准计算机语言

SQL语言1974年有Boyce和Chamberlin提出的,并且首先在IBM公司研制的关系数据库系统SystemR上实现。

经过多年发展,SQL已经成为数据库领域同意的数据操作标准语言,可以说几乎市面上所有的数据库系统都支持使用SQL语言来操作。

SQL语言的分类

由于数据库管理系统(数据库软件)功能非常多,不仅仅是存储数据,还要包括数据的管理、表的管理、库的管理、账户管理、权限管理等等。

所以基于操作数据库的SQL语言,也基于此功能划分为四类:

  1. 数据定义:DDL(Data Definition Language)

    库的创建删除、表的创建删除等

  2. 数据操控:DML(Data Manipulation Language)

    新增数据、删除数据、修改数据等

  3. 数据控制:DCL(Data Control Language)

    新增用户、删除用户、密码修改、权限管理等

  4. 数据查询:DQL(Data Query Language)

    基于需求查询和计算数据

SQL的语法特征

在学习DDL、DQL等之前,我们先来了解SQL的语法特征。

  1. SQL语言,大小写不敏感

  2. SQL可以单行或多行书写,最后以;号结束

  3. SQL支持注释:

  4. 单行注释:--注释内容 (-- 后面一定要有一个空格)

  5. 单行注释:# 注释内容 (#后面可以不加空格,推荐加上)

  6. 多行注释:/* 注释内容 */

show 
-- 这是第一种注释方法
# 这是第二种注释方法
/* 多行注释 
 * 
 */
databases;

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用 

 2.SQL的DDL

DDL是指数据定义语言,用来对数据库中库表建立删除定义的。

创建库

# 查看数据库
SHOW DATABASES
# 使用数据库
USE 数据库名称:
# 创建数据库
CREATE DATABASE数据库名称[CHARSET UTF8]:
# 删除数据库
DROP DATABASE数据库名称;
# 查看当前使用的数据库
SELECT DATABASE();

创建表和删除表

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用 

 

# 查看有哪些表
SHOW TABLES; # 注意要先选择数据库
# 创建表
create table 表名称(
    列名称 列类型,
    列名称 列类型,
    ……
);
​
drop table 表名称;
drop table if exists 表名称;
drop table where 条件判断;

列类型

-- 列类型:
int -- 整数
float -- 浮点数
varchar(长度) -- 文本,长度为数字,做最大长度限制
date -- 日期类型
timestamp -- 时间戳类型

3.SQL的DML

DML是指数据操作语言,用来对数据库中表的数据记录进行更新。

关键字:

  1. 插入INSERT

  2. 删除DELETE

  3. 更新UPDATE

基础语法

insert into 表(列1,列2,列3,列4,……,列N) values(值1,值2,值3,……,值N)[(值1,值2,值3,……,值N),……,(值1,值2,值3,……,值N)]

示例

create table student(
    id int,
    name varchart(20),
    age int
);
​
# 仅插入id数据
insert into student(id) values(1000),(1002),(1003);
# 插入全部id列数据
insert into student(id, name, age) values(1001, '张三', 20),(1002, '李四', 19),(1003, '王五', 21);
# 插入全部列数据,快捷写法
insert into student values(1001, '张三', 20),(1002, '李四', 19),(1003, '王五', 21);

数据删除DELETE

基础语法

DELETE FROM 表名称 WHERE 条件判断
条件判断:列 操作符 值
操作符:= < > <= >= != 等 如:
id = 5
id < 3
id >= 6
id != 5

演示案例

CREATE TABLE student(
    id int,
    name varchar(10),
    age int
);
​
INSERT INTO student(id) values(1), (2), (3);
/*
 * 等价于下面的代码
 * INSERT INTO student(id) values(1);
 * INSERT INTO student(id) values(2);
 * INSERT INTO student(id) values(3);
*/
​
insert into student(id, name, age) values(4, '张三', 31),(5, '李四',33);
delete from student where age = 33;

4.SQL的DQL

1.基础查询

基础语法:SELECT 字段列表|* FROM表

含义就是:从(FROM)表中,选择(SELECT)某些列进行展示

代码演示

select id, name from student;
select * from student;
select * from student where age > 20;
select * from student where id = '张三';

2.分组聚合

分组聚合应用场景,如:统计班级中男生和女生的人数。

这种需求就需要:

  1. 按性别分组

  2. 统计各组的人数

这就称之为:分组聚合。

基础语法

select 字段|聚合函数 from 表 [where 条件] group by 列
聚合函数:
sum(列) 求和
avg(列) 求平均值
min(列) 求最小值
max(列) 求最大值
count(列|*) 求数量

示例

select gender, avg(age), sum(age), min(age), max(age), count(avg) from student group by gender;

3.排序分页

结果排序

可以对查询结果,使用order by关键字,指定某个列进行排序,语法:

select 列|聚合函数|* from 表
where ……
group by ……
order by …… [ASC | DESC]

示例

select * from student where age > 20 order by age asc;
select * from student where age > 20 order by age desc;

结果分页限制

同样,可以使用limit关键字,对查询结果进行数量限制或分页显示,语法:

select 列|聚合函数|* from 表
where ……
group by ……
order by …… [asc | desc]
limit n[, m]

示例

select * from student limit 10; # 取10条信息
select * from student limit 10, 5; # 从第11条开始往后取5条
select * from student where age > 20 group by age
order by age limit 3;

5.Python操作MySQL基础使用

1.基础使用

pymysql

除了使用图像化工具以外,我们也可以使用编程编程语言来执行SQL从而操作数据库。

在Python中,使用第三方库:pymysql来完成对MySQL数据库的操作。

安装:pip install pymysql

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用 

 but,一开始,在我的命令提示符里面怎么都下不下来,这时候按照notice里面的To update run后面的绿色的代码,粘贴到下面来进行操作:

 一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用

 或者使用下列的方式:

pip install pymysql -i http://pypi.douban.com/simple/ --trusted-host [pypi.douban.com](http://pypi.douban.com/)

 一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用

 创建到MySQL的数据库链接

代码如下:

from pymysql import Connection
# 获取到MySQL数据库的连接对象
conn = Connection(
    host='localhost', # 主机名(或者IP地址)
    port=3306,        # 端口,默认3306
    user='root',      # 账户名
    password='123456' # 密码
)
# 打开MySQL数据库软件信息
print(conn.get_server_info())
# 关闭到数据库的链接
conn.close()

或者输入如下的代码:

import pymysql
​
db = pymysql.connect(
    host="localhost",
    port=3306,
    user='root',    #在这里输入用户名
    password='qazwsxedc.2345',     #在这里输入密码
    charset='utf8mb4'
    ) #连接数据库
​
cursor = db.cursor() #创建游标对象
​
sql = 'show databases' #sql语句
​
cursor.execute(sql)  #执行sql语句
​
one = cursor.fetchone()  #获取一条数据
print('one:',one)
​
many = cursor.fetchmany(3) #获取指定条数的数据,不写默认为1
print('many:',many)
​
all = cursor.fetchall() #获取全部数据
print('all:',all)
​
cursor.close()
db.close()  #关闭数据库的连接

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用 

 出现上图界面就说明pymysql成功将pycharm和mysql连接起来了。

执行查询性质的SQL语句

from pymysql import Connection
# 获取到MySQL数据库的连接对象
conn = Connection(
    host='localhost',
    port=3306,
    user='root',
    password='2345'
)
# 获取游标对象
cursor = conn.cursor()
conn.select_db("world")
# 使用游标对象,执行sql语句
cursor.execute("SELECT * FROM student")
# 获取查询结果
results = cursor.fetchall()
for r in results:
    print(r)
# 关闭到数据库的链接
conn.close()

2.数据插入

commit提交

pymysql在执行数据插入或其它产生数据更改的SQL语句时,默认是需要提交更改的,即,需要通过代码“确认”这种更改行为。

通过链接对象.commit()即可确认此行为。

from pymysql import Connection
# 获取到MySQL数据库的连接对象
conn = Connection(
    host='localhost',
    port=3306,
    user='root',
    password='2345'
)
# 获取游标对象
cursor = conn.cursor()
conn.select_db("world")
# 使用游标对象,执行sql语句
cursor.execute("insert into student values(10001, '唐七', 19)")
# 关闭到数据库的链接
conn.close()

6.综合案例

使用SQL语句和pymysql库完成综合案例的开发

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用 

 DDL定义

本次需求开发我们需要新建一个数据库来使用,数据库名称:py_sql

基于数据结构,可以得到建表语句:

CREATE TABLE order(
    order_date DATE,
    order_id, VARCHAR(255),
    money INT,
    province VARCHAR(10)
);

实现步骤

读取数据 -> 封装数据对象 -> 构建数据库链接 -> 写入数据库文章来源地址https://www.toymoban.com/news/detail-473986.html

import ..
text_file_reader = TextFileReader("D:/2011年1月销售数据.txt")
json_file_reader = JsonFileReader("0:/2011年2月销售数据JS0N.txt")
jan_data:list[Record] = text_file_reader.read_data()
feb_data:list[Record] = json_file_reader.read_data()
# 将2个月份的数据合并list来存储
all_data:list[Record] = jan_data + feb_data
    
# 构建MySQL链接对象
cursor = conn.cursor()
conn.select_db("py_sql")
# 组织SQL语句
for record in all_data:
    sql = f"insert into orders(order_data, order_id, money, province)" 
    	f"values('{record.date}','{record.order_id)'{record.noney},'{record.province}')"
	print(sql)
    cursor.excute(sql)
conn.close()

到了这里,关于一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 一篇文章带你玩转PostGIS空间数据库

    1.什么是空间数据库 人类理解世界其实是按照三维的角度,而传统的关系型数据库是二维的,要想描述空间地理位置,点、线、面,我们就需要一个三维数据库,即所谓空间数据库。 postGIS就是一个空间数据库。 2.空间数据库是怎么存储的 除了普通数据库所具备的字符串、数

    2024年04月10日
    浏览(40)
  • 【TDengine】一篇文章带你通过docker安装TDengine数据库

    目录 1、通过docker方式安装 2、相关步骤解释 3、停止运行taos与卸载 虽然并不推荐在生产环境中通过 Docker 来部署 TDengine 服务,但 Docker 工具能够很好地屏蔽底层操作系统的环境差异,很适合在开发测试或初次体验时用于安装运行 TDengine 的工具集。特别是,借助 Docker,能够比

    2024年02月15日
    浏览(46)
  • 【MySQL 数据库】6、一篇文章学习【索引知识】,提高大数据量的查询效率【文末送书】

    索引(index) 是帮助 MySQL 高效获取数据的数据结构(有序) 在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据, 这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是 索引 。 MySQL的索引是在存储引擎

    2024年02月08日
    浏览(54)
  • C语言数据在内存中的存续:一篇文章让你秒懂基础!

    JAMES别扣了-CSDN博客 💕在校大学生一枚。对IT有着极其浓厚的兴趣 ✨系列专栏目前为C语言初阶、后续会更新c语言的学习方法以及c题目分享. 😍希望我的文章对大家有着不一样的帮助,欢迎大家关注我,我也会回关,大家一起交流一起互动,感谢大家的多多支持哈! 🎉欢迎

    2024年04月13日
    浏览(35)
  • 一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案

    导航: 【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/黑马旅游/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码-CSDN博客 目录 一、分库分表基本概念 二、分库分表的场景和核心思想 三、分库分表具体步骤 3.1 分库分表的原则:能不分就

    2024年02月03日
    浏览(42)
  • 明天省赛,我都还不太熟悉Dev - C++,怎么切换成C++11了?它的报错看不懂呀,那花八分钟看看这篇文章吧~解决你的困惑。

    我不知道小伙伴们有没有dev5.4.0的资源,假如有那是最好的。假如没有了,也不用着急,我已经将它们上传到gitee上了。可以直接下载喔~ 学生机环境-Dev-cpp5.4.0及API帮助文档 这差不多是今年里最后一次系统的写蓝桥杯了吧,之后了,还是会更算法,只是不会这种系统的更蓝桥

    2023年04月22日
    浏览(33)
  • 一篇文章搞懂BUCK开关电源基础理论(上)

    欢迎关注我的公众号,每周电路与硬件知识分享↓ 在硬件开发的过程中,BUCK拓扑的开关电源是很常见的,相比于LDO的降压方式 BUCK降压的效率大大提高(尤其是在压差高、输出电流大的情况)。虽然BUCK降压电路有一些缺点,比如引入开关噪声、EMI、输出电压纹波相比于LDO偏

    2024年02月13日
    浏览(41)
  • 这篇文章把MOS管的基础知识讲透了

    MOS管(Metal-Oxide-Semiconductor field-effect transistor)是一种常见的半导体器件,它在数字电路、模拟电路、功率电子等领域都有广泛的应用。本文将从MOS管的基本结构、工作原理、参数特性等方面讲解MOS管的基础知识。 一、MOS管的基本结构 MOS管是由金属(Metal)、氧化物(Oxide)和

    2024年02月07日
    浏览(30)
  • 两万字的CAPL语法基础,一篇文章带你入门

    🍅 我是 蚂蚁小兵 ,专注于车载诊断领域,尤其擅长于对CANoe工具的使用 🍅 寻找组织 ,答疑解惑,摸鱼聊天,博客源码,点击加入👉【相亲相爱一家人】 🍅 玩转CANoe,博客目录大全,点击跳转👉 🍅 本章内容,面向CAPL初学者,超过两万字,超全超详细。 🍅 本节内容大

    2024年02月01日
    浏览(38)
  • Git新手?这篇文章带你飞!基础操作一网打尽!

    智能化校园:深入探讨云端管理系统设计与实现(一) 智能化校园:深入探讨云端管理系统设计与实现(二) Git(读音为/gɪt/) 是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。 git是世界上最先进的分布式版本控制系统(没有之一)

    2024年01月17日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包