数据库mysql基础(python)

Posted voong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据库mysql基础(python)相关的知识,希望对你有一定的参考价值。

E-R模型

  • 当前物理的数据库都是按照E-R模型进行设计的
  • E表示entry,实体
  • R表示relationship,关系
  • 一个实体转换为数据库中的一个表
  • 关系描述两个实体之间的对应规则,包括
    • 一对一
    • 一对多
    • 多对多
  • 关系转换为数据库表中的一个列 *在关系型数据库中一行就是一个对象

三范式

  • 经过研究和对使用中问题的总结,对于设计数据库提出了一些规范,这些规范被称为范式
  • 第一范式(1NF):列不可拆分
  • 第二范式(2NF):唯一标识(可以通过一个属性唯一的找到一个对象)
  • 第三范式(3NF):引用主键 (一般第二范式中的唯一标识就叫主键)
  • 说明:后一个范式,都是在前一个范式的基础上建立的

数据完整性

  • 一个数据库就是一个完整的业务单元,可以包含多张表,数据被存储在表中
  • 在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表添加一些强制性的验证,包括数据字段的类型、约束

字段类型

  • 在mysql中包含的数据类型很多,这里主要列出来常用的几种
  • 数字:int,decimal:小数如decimal(5,2)一共包含有5位数,小数占两位
  • 字符串:char:固定长度,varchar:不固定,可变,text:很多字符串,一个文本         如char(8):如果不够8个字符,会自动在右边补空格;varchar(8):就算不够8个字符,也不会自动补,超过8个,就直接截断了或者报错
  • 日期:datetime
  • 布尔:bit:后边什么都不写就默认存一个位,bit(8):存8个二进制的位

约束

  • 主键primary key   作用:1不会重复,唯一标识 2根据主键找数据速度快
  • 非空not null
  • 惟一unique:这个值不能重复,和主键的不同是唯一标识可以建多个
  • 默认default
  • 外键foreign key

使用图形窗口连接(windows上用navicat连接)

点击左上角连接,,连接名Mysql57,密码自己设的,应该是开机密码,连不上的话可能是mysql没有启动,(解决:右击计算机选管理,双击服务和应用程序,双击服务,找到mysql启动即可)鼠标右键新建数据库,数据库名字随便起,字符集合选utf8,排序规则选通用general即可(在数据库上右击,选择“删除数据库”可以完成删除操作)。

表操作

选中自己的数据库,新建表(一个表就是一个实体):

  点击“新建表”,弹出窗口,按提示填写信息

  • 主键的名称一般为id,设置为int型,无符号数,自动增长(表示由mysql系统负责维护这个字段的值,不需要手动维护,所以不用关心这个字段的具体值),非空
  •  
  • 点击“添加栏位”,(栏位名尽量用英文)可以添加一个新的字段(新的属性
  • 字符串varchar类型需要设置长度,即最多包含多少个字符
  • 点击“保存”,为表定义名称(如students)
  • 修改这个表:右键这个表名选设计表,尽量不要增加或删除表的栏位,这样的话就把表的结构改了,所以设计表时可以预留(多设)5个栏位左右
  • 向表中添加数据:表创建完了就可以添加数据了:
  • 打√确认你添加的这条数据点+号,再添加一条数据,
  • 删除选中要删的一行数据,delete(或右击选删除记录)这样删这条数据就真的没了,所以要用逻辑删除即在表中添加一个isDelete栏位,默认值为0,表示不删除想删哪条数据isDelete写1即可
  • 将来找数据时只显示isDelete为0的数据就好啦 

 

命令脚本操作(无需用navicat远程,直接在Ubantu里连接即可)

这里注意一下,在win系统中安装好客户端navicat及服务端mysql的情况下,以管理员身份运行cmd就可以用命令去操作数据库了:(输入命令前要启动服务MySQL)

启动服务器可以直接右击电脑管理也可以用命令:

 

     如:  

远程连接要把mysql这个库里的叫user的表中第一行的host值改为%,改完之后重启一下mysql服务就可以连别人的服务端mysql了(这里的密码要输别人家的mysql密码呀)

 好啦!下面是在ubantu中操作啦!(命令是一致的)

ubantu16.04安装mysql步骤:https://blog.csdn.net/weixin_42209572/article/details/98983741

其他平台上安装客户端,让ubantu中的msql允许远程连接即可

1.打开终端输入命令mysql -uroot -p (连接数据库服务器)回车后输入密码,当前设置的密码为mysql

             想看更多命令

          登录成功后,输入如下命令查看效果查看版本:select version();显示当前时间:select now();

         :在语句结尾要使用分号;

2.退出:quit或exit 

3.创建数据库

 先连接上

 显示当前所有的数据库: 

 查看当前用的是哪个数据库:select database();

 删掉名字叫做python3的数据库: 

 创建一个新的数据库(名字叫python3,指定字符集charset=utf8): 

 使用名叫python3的数据库: (这条命令就是切到了python3这个数据库了)

 看一下这个数据库里有哪些表:

  • 创建表(比如在python3这个数据库里创建一个名叫students的表):
  • create table 表名(列及类型);(注:最后要以分号结尾
    注意:这里有个错误,default 1,没有括号
  • 分析:id int auto_increment primary key not null,
  • 第一个栏位,名字叫id,int类型,设置为auto_increment自动增长,设置成主键 ,非空

       查看表

           

   修改表(表已经有数据的情况下不建议修改,可能会报错):增加栏位..

                       

        在students这个表中增加一个栏位:名叫isDelete。bit类型,默认值为0

  •   删除表drop table 表名; 更改表名称rename table 原表名 to 新表名;

   查看students这张表的数据

   往表中添加数据: 

         全列插入:insert into 表名 values(...)   要和表的顺序一致

                                   

                 (id是自动生成的这里写个0表示以下,然后写名字,性别,出生日期,是否逻辑删除这条数据)
        缺省插入insert into 表名(列1,...) values(值1,...)只需要和括号里指定的字段对应即可
  
          再如
        同时插入多条数据insert into 表名 values(...),(...)...;
           或insert into 表名(列1,...) values(值1,...),(值1,...)...;
    

       修改数据update 表名 set 列1=值1,... where 条件,对满足where条件的数据进行更改

       (修改id=2的出生日期)

        也可以改多个字段:注:不写where就是所有行都要改

      物理删除delete from 表名 where 条件 

      逻辑删除:

4.数据库备份和恢复:

备份:先退出mysql.    sudo -s:进入超级管理员   cd /var/lib/mysql:进入mysql库目录   mysqldump –uroot –p 数据库名 > ~/Desktop/备份文件.sql; (运行mysqldump命令)

 

 恢复:连接mysql,创建数据库

            接着退出连接,执行mysql -uroot –p 数据库名 < ~/Desktop/备份文件.sql,这样新建的数据库py31中的内容就和数据库python3中的一样了

 

以上是关于数据库mysql基础(python)的主要内容,如果未能解决你的问题,请参考以下文章

python 用于数据探索的Python代码片段(例如,在数据科学项目中)

python3 自动化之mysql操作python3下的mysql入门基础

《Python学习之路 -- Python基础之切片》

python之基础篇——模块与包

[vscode]--HTML代码片段(基础版,reactvuejquery)

常用python日期日志获取内容循环的代码片段