python的数据库编程
数据库的基础知识
一、数据库的概念
数据库将大量数据按照一定的方式组织并存储起来,是相互关联的数据的集合。数据库中的数据不仅包括描述事物数据的本身,还包括相关数据之间的联系。数据库可以分为关系型数据库和非关系型数据库。关系型数据库使用二维表来存储数据,非关系型数据库通常以对象的形式存储数据,目前的数据库管理系统几乎都支持关系模型。数据库具有如下特点:
以一定的方式组织、存储数据。
能为多个用户共享
具有尽可能小的冗余数据
是与程序彼此独立的数据集合
数据库系统
数据库系统是基于数据库的计算机应用系统,主要包括数据库、数据库管理系统、相关软硬件环境和数据库用户。其中,数据库管理系统是数据库系统的核心。
数据库管理系统
数据库管理系统是用来管理和维护数据库的、位于操作系统之上的系统软件,其主要功能如下:
1.数据定义功能。DBMS提供数据定义语言,用户通过它可以方便的对数据库中的对象进行定义,如对数据库、表、视图和索引进行定义。
2.数据操纵功能。DBMS向用户提供数据操纵语言,实现对数据库的基本操作,如查询、插入、删除和修改数据库中的数据。
3.数据库的运行管理。这是DBMS的核心部分,包括并发控制、存取控制、安全性检查、完整性约束条件的检查和执行,以及数据库的内部维护(如索引、数据字典的自动维护)等。所有数据库的操作都要在这些控制程序的统一管理下进行,以保证数据的安全性、完整性和多个用户对数据库的并发操作。
4.数据通信功能。包括与操作系统的联机处理、分时处理和远程作业传输的相应接口等,这一功能对分布式数据库系统尤为重要。
二、关系型数据库
关系型数据库是目前的主流数据库。通常,一个关系型数据库中可包含多个表,例如,一个雇员管理数据库中可以包含雇员表、订单表、工资表等多个表。通过在表之间建立关系,可以将不同表中的数据联系起来,实现更强大的数据管理功能。
关系数据库的基本概念
1.关系。一个关系就是一张二维表,通常将一个没有重复行、重复列的二维表看成一个关系,每个关系都一个关系名,也就是表名。
2.元组。二维表的水平方向的行在关系中称为元组。每个元组均对应表中的一条记录。
3.属性。二维表的垂直方向的列在关系中称为属性,每个属性都有一个属性名,属性值则是各个元组属性的取值。属性名也称为字段名,属性值也称为字段值。
4.域。属性的取值范围称为域。域作为属性的集合,其类型与范围与属性的性质及其所表示的意义来确定。同一属性只能在相同的域中进行取值。
5.关键字。其值能唯一的标识一个元组的属性或属性的组合称为关键字。关键字可表示为属性或属性的组合,例如,雇员表的id字段可以作为表示一条记录的关键字。
实体间的关系类型
1.一对一关系。
2.一对多关系。
3.多对多关系。
创建表 create table <表名>(
列名1 数据类型或长度1 列属性1,
列明2 数据类型和长度2 列属性2,
...
列明n 数据类型和长度n 列属性n
)
create table employee(
emp_id integer primary key,
emp_name varchar(20) NOT NULL,
sex char(2) default('男'),
title varchar(20),
wage float,
dep_id integer
)
primary key:定义此列为主关键字列。定义为主键的列可以唯一标识表中的每条记录。
NOT NULL:指定此列不允许为空,NULL表示允许为空,是默认设置。
default:指定此列的默认值。
查看表的结构(任选一个):
select *from sqlite_master where type="table"and name="emplyee"
.schema employee
删除表 drop table <表名>
drop table employee
向表中添加列 alter table <表名> add column <字段名>[ <类型>]
alter table employee add column tele varchar(50) not null
向表中插入数据 insert into <表名>[<字段名表>] values(<表达式表>)
insert into employee (emp_id,emp_name,sex,title,wage,dep_id) values(1132,'李四','男','部门经理',7548.6,11)
insert into employee (emp_id,emp_name,sex,title,wage,dep_id) values(1143,'王五','男','职员',6656,14)
insert into employee (emp_id,emp_name,sex,title,wage,dep_id) values(1036,'高七','女','经理',7600,10)
修改表中的数据 update <表名> set <字段名>=<表达式> [,<字段名2>=<表达式2>...] [where<条件表达式>]
update employee set wage=7550 where emp_name="李四"
删除数据 delete from <表名> [where <条件表达式>]
delete from employee where sex='女'
查询数据 select <字段名表>|* from <表名> [join <表名> on <连接条件>] [where <条件表达式>] [group by <分组字段名>[having <条件表达式>]] [oeder by <排序选项>[asc|desc]]
各项功能如下:
select子句说明要查询的字段名,如果是*,表示查询表中的所有字段。
from子句说明查询的数据来源,如果查询的结果来自多个表,需要join选项指明连接条件。
where子句说明查询的筛选条件。多个条件之间可以逻辑运算符and、or、not连接。
group by子句用于将查询结果按分组字段名分组。having子句必须跟随group by使用,它用来限定分组必须满足的条件。
oeder by子句用于对查询结果进行排序。
python的数据库编程的更多相关文章
- 运用Python语言编写获取Linux基本系统信息(三):Python与数据库编程,把获取的信息存入数据库
运用Python语言编写获取Linux基本系统信息(三):Python与数据库编程 有关前两篇的链接: 运用Python语言编写获取Linux基本系统信息(一):获得Linux版本.内核.当前时间 运 ...
- python之数据库编程
python之数据库编程 sqlite 1.前期准备工作 导入模块: import sqlite3 连接数据库 conn = sqlite3.connect("test.db") ...
- Python学习系列(七)( 数据库编程)
Python学习系列(七)( 数据库编程) Python学习系列(六)(模块) 一,MySQL-Python插件 Python里操作MySQL数据库,需要Python下安装访 ...
- Python程序设计9——数据库编程
1 数据持久化 持久化是将内存中的对象存储在关系数据库中,当然也可以存储在磁盘文件.XML数据文件中.实现数据持久化至少需要实现以下3个接口 void Save(object o):把一个对象保存到外 ...
- python 闯关之路四(下)(并发编程与数据库编程) 并发编程重点
python 闯关之路四(下)(并发编程与数据库编程) 并发编程重点: 1 2 3 4 5 6 7 并发编程:线程.进程.队列.IO多路模型 操作系统工作原理介绍.线程.进程演化史.特点.区别 ...
- python 教程 第二十章、 数据库编程
第二十章. 数据库编程 环境设置 1).安装MySQL-python http://www.lfd.uci.edu/~gohlke/pythonlibs/ MySQL-python-1.2.3.win ...
- Python黑帽编程 2.0 第二章概述
Python黑帽编程 2.0 第二章概述 于 20世纪80年代末,Guido van Rossum发明了Python,初衷据说是为了打发圣诞节的无趣,1991年首次发布,是ABC语言的继承,同时也是一 ...
- Python金融应用编程(数据分析、定价与量化投资)
近年来,金融领域的量化分析越来越受到理论界与实务界的重视,量化分析的技术也取得了较大的进展,成为备受关注的一个热点领域.所谓金融量化,就是将金融分析理论与计算机编程技术相结合,更为有效的利用现代计算技 ...
- 使用Python管理数据库
使用Python管理数据库 这篇文章的主题是如何使用Python语言管理数据库,简化日常运维中频繁的.重复度高的任务,为DBA们腾出更多时间来完成更重要的工作.文章本身只提供一种思路,写的不是很全 ...
随机推荐
- JQ,JQuery的ajax卡住了,浏览器页面卡住
在使用ajax的时候浏览器卡住了, 经过测试是因为在ajax中使用的data数据变量写错了 不存在也不报错,直接卡主了 好好检查一下吧.
- 浅析XML
概述XML文档结构 每个XML文档都分为两部分:序言(Prolog)和文档元素(或文档节点) 例子:写一段XML然后简单分析一下 <?xml version="1.0" en ...
- go1.18泛型的简单尝试
今天golang终于发布了1.18版本,这个版本最大的一个改变就是加入了泛型.虽然没有在beta版本的时候尝试泛型,但是由于在其他语言的泛型经验,入手泛型不是件难事~ 官方示例 Tutorial: G ...
- itertools.chain()and itertools.product()操作+pandas.DataFrame.transform
- SourceTree代码变更和FoxMail邮件管理(效率小计俩)
代码变更溯源 工作时,我们经常会想要查看一个类文件的变更历史,最常见的场景是:"卧槽,谁改了我的代码" 新版本的Xcode溯源自我感觉相当难用,所以这里我们介绍一个工具 Sourc ...
- ArcGIS热点分析
许多论文中一般会有热点分析图,ArcGIS中提供了热点分析的功能. 先看下描述:给定一组加权要素,使用 Getis-Ord Gi* 统计识别具有统计显著性的热点和冷点. 其实非常简单,今天博主就跟大家 ...
- 最大连续子序列和(DP)
DP入门_最大连续子序列(最大连续和) Description 有一条崎岖的山路,该山路被分成了n段(1<=n<=100,000),每段山路的驾驶体验不同.作为老司机的刘师傅给每段山路打分 ...
- mybatis连接sql
mysql6以上 com.mysql.cj.jdbc.Driver
- web服务器-nginx反向代理
web服务器-nginx反向代理 一. 代理介绍 代理是网络中使用比较常见的, 比如我们说的最多的就是FQ软件, 比如ss, 蓝灯等这些大家常用的软件,他们就是能改代理大家访问的国内无法访问的一些国外 ...
- 5月7日 python学习总结 MySQL数据库(一)
一.数据库介绍 1.数据库相关概念 数据库服务器(本质就是一台计算机,该计算机之上安装有数据库管理软件的服务端) 数据库管理系统RDBMS(本质就是一个C/S机构的套接字软件) 库(文件夹)===&g ...