首页 > 数据库 >2数据库之Mysql基本操作

2数据库之Mysql基本操作

时间:2023-12-25 23:45:10浏览次数:36  
标签:name 数据库 nid cursor result Mysql 基本操作 列名 select

                                                                                                                                    数据库基本类型、基本操作 一.数据库表基本操作 1.创建表     create table tb1(          `nid` int(10)  NOT NULL auto_increment primaey key,           `name` varchar(11) DEFAULT NULL     )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;         主键primaey key特殊的唯一索引,不能重复,不能为空,一个表只有一个主键     联合主键primaey key(nid,name),合起来唯一   2.数据类型:     数字类型         int整型         tinyint小整型,有符号是-128至127;没符号0-255         bigint大整型         decimal小数类型     字符串:         char 字符类型,定长,char(10),不管输入内容多少都占10个字节,最长255         varchar 字符类型,变长,varchar(10),输入超过10个字节会自己变长,最长255         大长度字符串         text         mediutext         longtext     blob 二进制类型,存取二进制文件     枚举:         enum           CREATE TABLE `db1` (           `nid` int(10) DEFAULT NULL,           `name` varchar(11) DEFAULT NULL,           `money` decimal(5,2) DEFAULT NULL,           `sex` enum('woman','man') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT 'man'         ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;       时间类型:         date   YYYY-MM-DD(1000-01-01/9999-12-31)         time    HH:MM:SS('-838:59:59'/'838:59:59')         year    YYYY(1901/2155)         datetime        YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)         timestamp    YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)     布尔值:Mysql无布尔类型,通过tinyint(1)构造的   3.删除表     drop table 表名   4.清空表     delete from 表名     truncate table 表名   5.修改表:     添加列:alter table 表名 add 列名 类型 删除列:alter table 表名 drop column 列名 修改列:         alter table 表名 modify column 列名 类型;  -- 类型         alter table 表名 change 原列名 新列名 类型; -- 列名,类型 添加主键:         alter table 表名 add primary key(列名); 删除主键:         alter table 表名 drop primary key;         alter table 表名  modify  列名 int, drop primary key; 添加外键:alter table 从表 add constraint 外键名称(形如:FK_从表_主表) foreign key 从表(外键字段) references 主表(主键字段); 删除外键:alter table 表名 drop foreign key 外键名称 修改默认值:ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;   删除默认值:ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;   二.数据库表内容基本操作 1.增加      insert into 表 (列名,列名...) values (值,值,值...)  insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...)    insert into 表 (列名,列名...) select (列名,列名...) from 表 2.修改      update 表 set name = 'alex' where id>1 3.删除     delete from 表   delete from 表 where id=1 and name='alex' 4.查找     select * from 表 select * from 表 where id > 1   select nid,name,gender as gg from 表 where nid > 1   5.其他     a、条件     select * from 表 where id > 1 and name != 'alex' and num = 12;       select * from 表 where id between 5 and 16;       select * from 表 where id in (11,22,33)     select * from 表 where id not in (11,22,33)     select * from 表 where id in (select nid from 表)   b、通配符     select * from 表 where name like 'ale%'  - ale开头的所有(多个字符串)     select * from 表 where name like 'ale_'  - ale开头的所有(一个字符)   c、限制     select * from 表 limit 5;            - 前5行     select * from 表 limit 4,5;          - 从第4行开始的5行     select * from 表 limit 5 offset 4    - 从第4行开始的5行   d、排序     select * from 表 order by 列 asc              - 根据 “列” 从小到大排列     select * from 表 order by 列 desc             - 根据 “列” 从大到小排列     select * from 表 order by 列1 desc,列2 asc    - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序   e、分组     select num from 表 group by num     select num,nid from 表 group by num,nid     select num,nid from 表  where nid > 10 group by num,nid order nid desc     select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid       select num from 表 group by num having max(id) > 10       特别的:group by 必须在where之后,order by之前   f、连表     无对应关系则不显示     select A.num, A.name, B.name     from A,B     Where A.nid = B.nid       无对应关系则不显示     select A.num, A.name, B.name     from A inner join B     on A.nid = B.nid       A表所有显示,如果B中无对应关系,则值为null     select A.num, A.name, B.name     from A left join B     on A.nid = B.nid       B表所有显示,如果B中无对应关系,则值为null     select A.num, A.name, B.name     from A right join B     on A.nid = B.nid   g、组合     组合,自动处理重合     select nickname     from A     union     select name     from B       组合,不处理重合     select nickname     from A     union all     select name from B     三.python pymysql进行数据库操作 1.基本操作

                                                                                                                                    数据库基本类型、基本操作
一.数据库表基本操作
1.创建表
    create table tb1(
         `nid` int(10)  NOT NULL auto_increment primaey key,
          `name` varchar(11) DEFAULT NULL
    )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
   
    主键primaey key特殊的唯一索引,不能重复,不能为空,一个表只有一个主键
    联合主键primaey key(nid,name),合起来唯一

2.数据类型:
    数字类型
        int整型
        tinyint小整型,有符号是-128至127;没符号0-255
        bigint大整型
        decimal小数类型
    字符串:
        char 字符类型,定长,char(10),不管输入内容多少都占10个字节,最长255
        varchar 字符类型,变长,varchar(10),输入超过10个字节会自己变长,最长255
        大长度字符串
        text
        mediutext
        longtext
    blob 二进制类型,存取二进制文件
    枚举:
        enum

        CREATE TABLE `db1` (
          `nid` int(10) DEFAULT NULL,
          `name` varchar(11) DEFAULT NULL,
          `money` decimal(5,2) DEFAULT NULL,
          `sex` enum('woman','man') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT 'man'
        ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

    时间类型:
        date   YYYY-MM-DD(1000-01-01/9999-12-31)
        time    HH:MM:SS('-838:59:59'/'838:59:59')
        year    YYYY(1901/2155)
        datetime        YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)
        timestamp    YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
    布尔值:Mysql无布尔类型,通过tinyint(1)构造的

3.删除表
    drop table 表名

4.清空表
    delete from 表名
    truncate table 表名

5.修改表:
    添加列:alter table 表名 add 列名 类型
删除列:alter table 表名 drop column 列名
修改列:
        alter table 表名 modify column 列名 类型;  -- 类型
        alter table 表名 change 原列名 新列名 类型; -- 列名,类型
添加主键:
        alter table 表名 add primary key(列名);
删除主键:
        alter table 表名 drop primary key;
        alter table 表名  modify  列名 int, drop primary key;
添加外键:alter table 从表 add constraint 外键名称(形如:FK_从表_主表) foreign key 从表(外键字段) references 主表(主键字段);
删除外键:alter table 表名 drop foreign key 外键名称
修改默认值:ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
  删除默认值:ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;

二.数据库表内容基本操作
1.增加
     insert into 表 (列名,列名...) values (值,值,值...)
 insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...)
   insert into 表 (列名,列名...) select (列名,列名...) from 表
2.修改
     update 表 set name = 'alex' where id>1
3.删除
    delete from 表
  delete from 表 where id=1 and name='alex'
4.查找
    select * from 表
select * from 表 where id > 1
  select nid,name,gender as gg from 表 where nid > 1

5.其他
    a、条件
    select * from 表 where id > 1 and name != 'alex' and num = 12;
 
    select * from 表 where id between 5 and 16;
 
    select * from 表 where id in (11,22,33)
    select * from 表 where id not in (11,22,33)
    select * from 表 where id in (select nid from 表)
 
b、通配符
    select * from 表 where name like 'ale%'  - ale开头的所有(多个字符串)
    select * from 表 where name like 'ale_'  - ale开头的所有(一个字符)
 
c、限制
    select * from 表 limit 5;            - 前5行
    select * from 表 limit 4,5;          - 从第4行开始的5行
    select * from 表 limit 5 offset 4    - 从第4行开始的5行
 
d、排序
    select * from 表 order by 列 asc              - 根据 “列” 从小到大排列
    select * from 表 order by 列 desc             - 根据 “列” 从大到小排列
    select * from 表 order by 列1 desc,列2 asc    - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序
 
e、分组
    select num from 表 group by num
    select num,nid from 表 group by num,nid
    select num,nid from 表  where nid > 10 group by num,nid order nid desc
    select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid
 
    select num from 表 group by num having max(id) > 10
 
    特别的:group by 必须在where之后,order by之前
 
f、连表
    无对应关系则不显示
    select A.num, A.name, B.name
    from A,B
    Where A.nid = B.nid
 
    无对应关系则不显示
    select A.num, A.name, B.name
    from A inner join B
    on A.nid = B.nid
 
    A表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A left join B
    on A.nid = B.nid
 
    B表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A right join B
    on A.nid = B.nid
 
g、组合
    组合,自动处理重合
    select nickname
    from A
    union
    select name
    from B
 
    组合,不处理重合
    select nickname
    from A
    union all
    select name from B


三.python pymysql进行数据库操作
1.基本操作

import pymysql

# 连接数据库
conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",)

# 创建游标进行数据库操作以及获取数据
cursor=conn.cursor()

# 执行sql语句,并返回影响的行数
# cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",))
# 插入多条数据
row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])
print(row)

print(cursor.lastrowid)
# 提交数据
conn.commit()

# 关闭游标
cursor.close()

# 关闭数据库连接
conn.close()
2.自动提交

import pymysql

# 连接数据库
conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)

# 创建游标进行数据库操作以及获取数据
cursor=conn.cursor()

# 执行sql语句,并返回影响的行数
# cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",))
# 插入多条数据
row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])
print(row)

print(cursor.lastrowid)
# 提交数据,如果创建数据库连接时autocommit=True会帮我们进行自动提交
# conn.commit()

# 关闭游标
cursor.close()

# 关闭数据库连接
conn.close()
3.查询数据

import pymysql

# 连接数据库
conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)

# 创建游标进行数据库操作以及获取数据
cursor=conn.cursor()

# 执行sql语句,并返回影响的行数
# cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",))
# 插入多条数据
# row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])

# 查询数据
cursor.execute("select * from user")
# fetchone返回一条数据,类型是元祖
# result=cursor.fetchone()
# print(type(result),result)

# fetchmany返回多条数据,类型是元祖,数据展示是元祖里面包元祖
result=cursor.fetchmany(3)
print(type(result),result)

# fetchmany返回多条数据,类型是元祖,数据展示是元祖里面包元祖
result=cursor.fetchall()
print(type(result),result)

# 提交数据
# conn.commit()

# 关闭游标
cursor.close()

# 关闭数据库连接
conn.close()
4.返回结果格式化显示cursor=pymysql.cursors.DictCursor,且返回的数据包含列名

import pymysql

# 连接数据库
conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)

# 创建游标进行数据库操作以及获取数据
cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)

# 执行sql语句,并返回影响的行数
# cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",))
# 插入多条数据
# row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])

# 查询数据
cursor.execute("select * from user")
# fetchone返回一条数据,类型是字典
result=cursor.fetchone()
print(type(result),result)

# fetchmany返回多条数据,数据展示是列表里面包含字典
result=cursor.fetchmany(3)
print(type(result),result)

# fetchmany返回多条数据,数据展示是列表里面包含字典
result=cursor.fetchall()
print(type(result),result)

# 提交数据
# conn.commit()

# 关闭游标
cursor.close()

# 关闭数据库连接
conn.clos
View Code

 

2.自动提交 import pymysql   # 连接数据库 conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)   # 创建游标进行数据库操作以及获取数据 cursor=conn.cursor()   # 执行sql语句,并返回影响的行数 # cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",)) # 插入多条数据 row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)]) print(row)   print(cursor.lastrowid) # 提交数据,如果创建数据库连接时autocommit=True会帮我们进行自动提交 # conn.commit()   # 关闭游标 cursor.close()   # 关闭数据库连接 conn.close() 3.查询数据 import pymysql   # 连接数据库 conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)   # 创建游标进行数据库操作以及获取数据 cursor=conn.cursor()   # 执行sql语句,并返回影响的行数 # cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",)) # 插入多条数据 # row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])   # 查询数据 cursor.execute("select * from user") # fetchone返回一条数据,类型是元祖 # result=cursor.fetchone() # print(type(result),result)   # fetchmany返回多条数据,类型是元祖,数据展示是元祖里面包元祖 result=cursor.fetchmany(3) print(type(result),result)   # fetchmany返回多条数据,类型是元祖,数据展示是元祖里面包元祖 result=cursor.fetchall() print(type(result),result)   # 提交数据 # conn.commit()   # 关闭游标 cursor.close()   # 关闭数据库连接 conn.close() 4.返回结果格式化显示cursor=pymysql.cursors.DictCursor,且返回的数据包含列名 import pymysql   # 连接数据库 conn=pymysql.connect(host="127.0.0.1",port=3306,user="root",password="123456",database="a",autocommit=True)   # 创建游标进行数据库操作以及获取数据 cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)   # 执行sql语句,并返回影响的行数 # cursor.execute("""insert into user(username,password,email) values(%s,%s,%s)""",("haha","7890","[email protected]",)) # 插入多条数据 # row=cursor.executemany("""insert into user(username,password,email) values(%s,%s,%s)""",[("haha","7890","[email protected]",),("gg","7890","[email protected]",)])   # 查询数据 cursor.execute("select * from user") # fetchone返回一条数据,类型是字典 result=cursor.fetchone() print(type(result),result)   # fetchmany返回多条数据,数据展示是列表里面包含字典 result=cursor.fetchmany(3) print(type(result),result)   # fetchmany返回多条数据,数据展示是列表里面包含字典 result=cursor.fetchall() print(type(result),result)   # 提交数据 # conn.commit()   # 关闭游标 cursor.close()   # 关闭数据库连接 conn.clos

标签:name,数据库,nid,cursor,result,Mysql,基本操作,列名,select
From: https://www.cnblogs.com/zongchen/p/17927216.html

相关文章

  • MySQL-索引数据结构
    BTreeB-树即B树。指的是BalanceTree,也就是平衡树,平衡树是一颗查找树,并且所有叶子节点位于同一层。每个结点存储M/2到M个关键字,非叶子结点存储指向关键字范围的子结点。所有关键字在整颗树中出现,且只出现一次,非叶子结点可以命中。B+Tree是B树的一种变形,它是基于B......
  • openGauss学习笔记-172 openGauss 数据库运维-备份与恢复-导入数据-分析表172.1 分析
    openGauss学习笔记-172openGauss数据库运维-备份与恢复-导入数据-分析表执行计划生成器需要使用表的统计信息,以生成最有效的查询执行计划,提高查询性能。因此数据导入完成后,建议执行ANALYZE语句生成最新的表统计信息。统计结果存储在系统表PG_STATISTIC中。172.1分析表ANALYZE......
  • openGauss学习笔记-173 openGauss 数据库运维-备份与恢复-导入数据-对表执行VACUUM
    openGauss学习笔记-173openGauss数据库运维-备份与恢复-导入数据-对表执行VACUUM如果导入过程中,进行了大量的更新或删除行时,应运行VACUUMFULL命令,然后运行ANALYZE命令。大量的更新和删除操作,会产生大量的磁盘页面碎片,从而逐渐降低查询的效率。VACUUMFULL可以将磁盘页面碎片恢......
  • MySQL索引-索引结构
    索引是什么索引是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查询算法,这种数据结构就是索引。优缺点:优点:提高数据检索效率,降低数据库的IO成本通......
  • bt 面板面板里显示不出的域名和数据库信息
    /panel/data/db/site.db面板里显示的域名文件所在数据库:面板里搜的到的包含域名文件: SQLite在Windows上的管理工具cd /www/server/panel/data/db[root@16217-139data]#sqlite3site.dbsqlite>.help查看数据库文件信息命令(注意命令前带字符'.'):sqlite>.database查......
  • mysql主从同步原理
    (1)master服务器将数据的改变记录二进制binlog日志,当master上的数据发生改变时,则将其改变写入二进制日志中(2)slave服务器会在一定时间间隔内对master二进制日志进行探测其是否发生改变,如果发生改变,则开始一个IOThread请求master二进制事件(3)同时主节点大每个O线程启动一个du......
  • 数据库事务的作用
    数据库事务的主要作用是确保数据库在执行多个相关操作时能够保持一致性和完整性。事务是指一组数据库操作语句,这些语句将作为一个逻辑单元一起执行,要么全部执行成功,要么全部不执行。当一个事务成功提交后,数据库中的数据应该保持一致性状态,反之如果事务执行出错或中断,则要回滚事务,使......
  • 数据库 Mysql 多表查询,left join联合两个sql示例
    SELECTt1.RowID,t1.UserID,t1.CreateDate,t1.BatchState,t2.InputDataCount,t1.QtyFROM(SELECT@curRow:=@curRow+1ASRowID,`UserID`,DATE_FORMAT(CreateDate,'%Y-%m-%d')ASCreateDate,......
  • 数据库 MySql快速导入外部数据库流程
    适用于新安装MySql本地没有数据情况外部MySql数据库文件任务管理器停用Mysql进程将外部文件替换本地默认文件即可重启电脑导入完成。......
  • 保姆级搭建Mysql 并进行视图可视化操作
    安装MySQL数据库选择mysql5.7.36_x32.msi”,双击运行,如下图所示:在此窗口中,选择“Custom”选项,点击“Next>”进入下一步;在此窗口中,选择+号下的MySQLServer5.7.36–x64,点击中间的绿色箭头符号,添加完成如下图所示:然后点击“Next>”进入下一步进行安装;继续点击“Next>”进入下一步......