首页 > 数据库 >一文入门mysql 数据库

一文入门mysql 数据库

时间:2024-08-19 19:57:33浏览次数:14  
标签:cur 数据库 id user mysql self select 入门

一、数据库概述


什么是数据库

        数据库是一个用于存储和管理数据的仓库。数据按照特定的格式存储,可以对数据库中的数据进行增加、修改、删除和查询操作。数据库的本质是一个文件系统,按照一定的逻辑结构组织数据,以方便高效地访问和维护。

什么是数据库管理系统

        数据库管理系统(DataBase Management System,DBMS)是一个操作和管理数据库的软件。它用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据。

常见的数据库管理系统

MYSQL :

MySQL 不仅用于小型数据库,还可以扩展到大型企业级应用场景。它在许多高流量的网站和大型企业系统中得到了广泛应用。
虽然 Oracle 收购了 MySQL,但开源版本仍然存在且免费。MySQL 有多个版本(如社区版、企业版等),其中一些版本收费,但免费的社区版仍在维护和更新。
Oracle :收费的大型关系数据库管理系统,主要用于大型企业级应用。

SQLServer:MicroSoft 公司收费的中型的数据库。SQL Server 不仅适用于 C# 和 .NET 语言,还可以与其他编程语言(如 Java、Python、PHP 等)一起使用。

SQLite : 嵌入式的小型数据库,SQLite 不仅应用于手机端,还可以应用于桌面应用程序和物联网(IoT)设备等。

PostgreSQL:PostgreSQL 是一种开源的关系数据库管理系统,功能强大且可扩展,适用于各种规模的应用场景。它在许多大型企业和开源项目中得到了广泛应用。

NoSQL:除了上述描述的关系数据库管理系统外,还有一类称为 NoSQL(Not Only SQL)数据库,它们使用非关系模型来存储和管理数据。这些数据库包括 MongoDB(文档存储)、Redis(键值存储)、Apache Cassandra(列存储)和 Neo4j(图数据库)等。这些数据库在大数据、分布式系统和实时应用场景中具有优势。

数据库表

数据库中以表为组织单位存储数据。

表类似我们的Java类,每个字段都有对应的数据类型。

那么用我们熟悉的java程序来与关系型数据对比,就会发现以下对应关系。

类----------表

类中属性----------表中字段

对象----------记录

二、MySql数据库

1.安装

可以看我之前作品

2.登录,在windows命令窗口

mysql -u(用户名) -p(密码) -h(主机ip地址) -P(主机ip端口号) 

3.基础指令

(1) 数据库基本指令:

show  databases;  显示所有的数据库

create database 数据库名 charest=utf8;  创建数据库

drop database 数据库名;  删除数据库

use 数据库名; 使用数据库

select database();  查看当前使用的数据库

(2)数据表基本指令:

show tables;  显示数据库中的所有数据表

create  table 表名 (列名 类型 约束1 约束2...,列名  类型  约束1  约束2...);  创建数据表

desc 表名;  查看数据表结构

drop table 表名;  删除数据表

(3)数据表中列的增删改:

alter table 数据表名 drop 列名;  删除列

alter table 数据表名  add  列名 类型 约束1  约束2...;  创建列

alter table 数据表名  change 列名 新列名 类型 约束1  约束2...;  修改列

(4)列的约束条件:

1.主键 :primary  key ,可以确定唯一的一行

2.非空 :not null ,不能为空,必须有值

3.自增长: auto_increment  ,每次+1

4.唯一: unique, 列中内容不重复

5.默认:default,默认值

6.外键:foreign,与其他表关联,是其他表的主键

7.检查:check,Mysql 8 才有,检查满足条件

4.高级指令


(1)、CURD  增删改查

查:

1.select * from 数据表名 where 条件; 慎用,非常耗时

2.select 列名,列名,列名 from 数据表名 where 条件;

3.select  列名 as 别名,列名 as 别名 from 数据表名 where 条件;

条件: 

1.比较运算符: =   >  >=  <  <=  !=  <>

2.逻辑运算符:and or  not

3.成员运算符: in [a,b,c]

4.between a and b

5.判断是否为空:is null  is not null

6.like   % 代表多个字符,_ 代表一个字符

关联查询:表与表之前存在关联关系
嵌套查询:第一次查询的结果作为第二次查询的条件 

表连接:
1.笛卡尔连接:一个表中每一行都和另外一个表中所有行连接

2.内连接 :inner join 

举例:select user.id as 用户id, user.username as  用户名, role.nick as 昵称, role.level as 等级 from user inner join role  on user.id = role.user_id;

3.外连接:左外连接,右外连接

左外连接:left join以左表为主,左表条件满足 正常显示 不满足 右侧补null。

举例:select * from user left join role on user.id = role.user_id;

右外连接:right join以右表为主,右表条件满足 正常显示 不满足 左侧补null。

举例:select * from role right join user on user.id = role.user_id;

4.全连接:full join,left join   union  right join, mysql不支持关键字 full join

举例: select * from user right join role on user.id = role.user_id union  select * from user left join role on user.id = role.user_id;

1. insert into  表名 values (列1, 列2,列n),(列1, 列2, 列n)....  列的个数与值的个数一致

2 . insert into  表名  (列1, 列2) values (值1, 值2), (值1, 值2)...    可以指定哪些列的数据,没有默认值的列必须插入

3. insert into   表名  set  列1=值1,列2=值2;  插入1行指明插入的列与其值

update 数据表名 set 列名1 = 值1 where 条件;  如果没有条件就修改整个表

delete from 表名 where 条件;  如果没有条件就清空表

(2)、分组、分页、排序


1. 去重:distinct  ,单独列展示 并对列去重

举例:

 select  distinct user_id from role;

2. 分组:group by ,一般会结合count (*)进行统计

举例:

 select info as '组信息', count(*) as 个数 from role group by info;

3. 分页:limit ,一个数字n 代表 前n个,两个数字start, count,每页显示count个  第n页公式:(n-1)* count, count

4. 排序: order by, asc 升序、desc 降序

举例:

select * from role order by user_id desc , id  desc  ; # id 降序

(3)、用户操作

1.root系统管理员+ 其他用户,% 代表所有ip都可以访问

2.创建用户:create user '用户名'@'%' identified by '123456';

3.分配权限:grant 权限列举 to ‘用户名’@‘%’ on  数据名.表名 ,all 所有权限,*.*  所有数据库中的所有表

4. 刷新权限: flush privileges;

5. 删除用户:drop user  '用户名'@'%';

6. 修改密码:alter user ‘用户名’@‘%’  identified by ‘123456’;

(4)、外键

1.创建、添加外键:constraint  外键名 foreign key   (列名)  references  表 (列名)on update  cascade  on  delete   cascade;

2. 删除外键:alter table 表名 drop foreign key 外键名;

(5)、函数

1. 查看当前数据库:select database();

2. 查看当前用户: select  user();

3. 查看版本: select version();

4. 现在时间: select now();

5. 时间戳: select unix_timestamp();

(6)、特殊数据类型

1. int

2. varchar、char

3. datetime,default current_timestamp,default current_timestamp on update current_timestamp

4. enum,enum("男“,”女“, ”保密“)  default "保密"

三、pymysql


1、pymysql 基础使用


(1).安装:终端输入:pip install pymysql

(2). 导包

import pymysql

(3). 构建连接实例

con = pymysql.connect(user="qyc", password='123456')

(4). 使用数据库

con.select_db("python2407")

(5). 创建游标(游动的鼠标),用于执行sql语句

cur = con.cursor()

5.1 使用游标执行sql

row = cur.execute("show tables")
print(f"{row}个表")

5.2 打印所有表 fetchall

datas = cur.fetchall()
for data in datas:
    print(data[0])

5.3 打印一个表(游标前进一位) fetchone

datas = cur.fetchone()
print(datas[0])
datas = cur.fetchone()
print(datas[0])

5.4 打印n个表  fetchmany(size=n) 取n个

datas = cur.fetchmany(size=2)
print(datas)

5.5 游标滚动,默认相对(relative), (absolute)绝对,正值前进,负值后退

cur.scroll(1)  # 打印 第一个
data = cur.fetchone()
print(data)
cur.scroll(0, mode="absolute") # 同样打印第一个
data = cur.fetchone()
print(data)

(6). 关闭游标,关闭连接

cur.close() 
con.close()


2、查询插入参数


(1). 查询单个数据

cur.execute("select * from role where nick =%s or level = %s", args=('射手', 3))
#结果:(4, '射手', 3, 1002)

(2).查询多行

cur.executemany("select * from role where id = %s and level =%s", [(3, 1), (5, 15)])
#结果:(5, '打野', 15, 1003)

(3). 插入单行数据

row = cur.execute("insert into student values (%s,%s,%s)", (0, '赵六', 30))

插入前:

插入后:

(4). 插入多行数据

row = cur.executemany("insert into student values (%s,%s,%s)", [(0, '吕布', 6), (0, '李白', 3)])

插入前:

插入后:

3、pymysql 辅助类


笔者编写了一个小小案例,应该挺好理解的,创建类,封装了进入mysql的方法,每次初始化的时候都可以进入mysql

import pymysql
 
 
class MySqlHelper:
    def __init__(self, db="python2407"):
        self.con = None
        self.cur = None
        self.con = pymysql.connect(user="root", password="123456", database=db)
        self.cur = self.con.cursor()
 
    def query_one(self, query, args=None):
        self.cur.execute(query, args)
        return self.cur.fetchone()
 
    def query_all(self, query, args=None):
        self.cur.execute(query, args)
        return self.cur.fetchall()
 
    def update(self, query, args=None):
        row = self.cur.execute(query, args)
        self.con.commit()
        return row
 
    def __del__(self):
        if self.cur:
            self.cur.close()
        if self.con:
            self.con.close()
 
 
class UserMysqlHelper:
    @staticmethod
    def login(username, password):
        sql = MySqlHelper()
        user = sql.query_one("select * from user where username=%s and password = %s ", (username, password))
        return user
 
    @staticmethod
    def regist(username, password):
        sql = MySqlHelper()
        row = sql.update("insert into user (username,password) values (%s,%s)", (username, password))
        return row
 
 
def main():
    while True:
        menu = """0、退出
1、登录
2、注册
"""
        print(menu)
        option = input("输入数字选择对应选项")
        if option not in [str(i) for i in range(3)]:
            print(f"输入不合法,重新输入")
        else:
            if option == "0":
                break
            elif option == "1":
                while True:
                    username = input("输入用户名")
                    if 2 <= len(username) <= 4:
                        break
                    else:
                        print(f"输入不合法,重新输入")
                while True:
                    password = input("请输入密码")
                    if 2 <= len(password) <= 10:
                        break
                    else:
                        print(f"输入不合法,重新输入")
                user = UserMysqlHelper.login(username, password)
                if user:
                    print(f"登陆成功")
            elif option == "2":
                while True:
                    username = input("输入用户名")
                    if 2 <= len(username) <= 4:
                        break
                    else:
                        print(f"输入不合法,重新输入")
                while True:
                    password = input("请输入密码")
                    if 2 <= len(password) <= 10:
                        break
                    else:
                        print(f"输入不合法,重新输入")
                while True:
                    password2 = input("请再次输入密码")
                    if 2 <= len(password2) <= 10:
                        break
                    else:
                        print(f"输入不合法,重新输入")
                if password != password2:
                    print(f"密码不一致,重新注册")
                else:
                    row = UserMysqlHelper.regist(username, password)
                    if row > 0:
                        print(f"注册成功")
                    else:
                        print(f"注册失败,重新注册")
 
 
if __name__ == '__main__':
    main()

4. pymysql 执行函数与过程


(1). 构建过程函数

构建函数:

 输入:

函数执行前:

单击 运行

输入参数:100

函数运行后:多了100个数据

(2)、构建函数

保存,运行,输入参数  a,b

 结果:

以上就是小编作为初学者小白使出浑身解数写的mysql了,创作不易,脑袋要爆炸了,请大家多多点赞支持!欢迎大佬指点!

 

标签:cur,数据库,id,user,mysql,self,select,入门
From: https://blog.csdn.net/dudnf/article/details/141331528

相关文章

  • 学的时候不小心差点把数据库填满了~
    一.SQL-DDL(数据定义语言)1.数据库操作1.查询SHOWDATABASES;SELECTDATABASE();创建CREATEDATABASE[IFNOTEXISTS]数据库名[DEFAULTCHARSET字符集][COLLATE排序规则];eg:CREATEDATEBASE[IFNOTEXISTS]ITDEFAULTCHARSETUTF8MB4;删除DROP[IFEXIST......
  • oracle数据库缓存区高速缓存区
    文章目录Oracle数据库高速缓存一、数据库高速缓存的基本概念二、数据库高速缓存的工作原理三、数据库高速缓存的配置四、数据库高速缓存的块管理五、多种数据块大小的高速缓存配置Oracle数据库高速缓存一、数据库高速缓存的基本概念1、数据库高速缓存(DatabaseB......
  • Centos7使用RPM包安装Oracle21c数据库(EE)
    Centos7使用RPM包安装Oracle21c数据库(EE)官方下载链接21c标准版安装包信息:文件名:LINUX.X64_213000_db_home.zip(64-bit)(3,109,225,519bytes)(sha256sum-c05d5c32a72b9bf84ab6babb49aee99cbb403930406aabe3cf2f94f1d35e0916)21cxe版安装包信息:文件名:oracle-data......
  • [Mysql]日志刷盘总结
    Mysqlredolog的刷盘时机mysql正常关闭的时候redologbuffer写入超过一半的时候后台线程每隔一秒写入磁盘一次0把redologbuffer中的内容刷盘2把pagecache中的内容刷盘事务提交的时候0每次提交事务,redolog留在buffer中不写入磁盘1每次提交事务,redolog写入磁......
  • C#基础:数据库中使用Linq作分组处理(反射/直接分组)
    目录一、使用反射分组二、不使用反射分组三、调用示例四、代码demo一、使用反射分组privatestaticList<GroupList<T>>GetGroupList<T>(List<T>entities,stringgroupByProperty){//获取分组字段的类型varpropertyInfo=typeof(T).GetProperty(groupBy......
  • Oracle21c数据库安装问题记录
    Oracle21c数据库安装问题记录1.安装问题1.1Oracle监听器配置错误:为该监听程序提供的信息正由此计算机上的其他软件使用转载链接:https://blog.itpub.net/23557469/viewspace-1117140/在Linux上安装好Oracle10g,配置监听器,却得到:为该监听程序提供的信息正由此计算机上的其......
  • Sybase ASE数据库 1615
    SybaseASE数据库16/15.7安装安装参考博客:windows/Linux下安装SybaseASE16/15.7-CSDN博客。1.下载安装包SYBASE官网下载以下安装可成功,有免费安装版本linux:SybaseASE15.7链接:https://pan.baidu.com/s/10aJLz3hP-tCOHWBrktZjug提取码:a47tSybaseASE16链接:https:......
  • Centos7使用RPM包安装Oracle21c数据库(XE)
    Centos7使用RPM包安装Oracle21c数据库(XE)官方下载链接21c标准版安装包信息:文件名:LINUX.X64_213000_db_home.zip(64-bit)(3,109,225,519bytes)(sha256sum-c05d5c32a72b9bf84ab6babb49aee99cbb403930406aabe3cf2f94f1d35e0916)21cxe版安装包信息:文件名:oracle-data......
  • ctfshow-web入门-sql注入(web224-web230)文件类型注入、routines存储过程与函数状态、ha
    目录1、web2242、web2253、web2264、web2275、web2286、web2297、web2301、web224登录页面测了下没发现注入点存在robots.txt访问/pwdreset.php  ,是管理员密码重置的页面直接重置密码,这里以123456为例使用admin/123456登录 来到一个文件生成界......
  • MySQL面试相关精选
    一、数据库三大范式第一范式:1NF原子性列或者字段不能再分,要求属性具有原子性,不可再分解;单一属性由基本类型构成,包括整型、实数、字符型、逻辑型、日期型等。第二范式:2NF唯一性一张表只说一件事,是对记录的惟一性约束,要求记录有惟一标识。第三范式:3NF直接性数据不能存......