当前位置:Gxlcms > 数据库问题 > 数据库mysql基础(python)

数据库mysql基础(python)

时间:2021-07-01 10:21:17 帮助过:33人阅读

  • 第三范式(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的数据就好啦 

     

    命令脚本操作(无需远程,直接在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)

    标签:插入   进制   mamicode   art   保存   速度   第三范式   nav   多命令   

    人气教程排行