• 第十三章 数据库


    目录

    一、数据库

    1.1 基础操作

    1.1.1 连接数据库

    1.1.2 指定端口

    1.1.3 mysql授权语句

    1.1.4 创建数据库

    1.1.5 查看数据库

    1.1.6 选择数据库&查看你当前使用的数据库

    1.1.7 删除数据库 DROP  DATABASE;

    1.1.8 创建表

    1.1.9 插入表数据&查询表数据

    1.1.10 删除表数据

    1.1.11 更新表数据

    1.1.12 删除所有表数据

    1.1.13 删除表数据及表结构

    1.1.14 delete、truncate、drop的区别

    1.1.15 查看是否设置自动提交

    1.1.16 查看表创建的语句

    1.1.17 查看表字段信息

    1.1.18 添加/删除表索引

    1.1.19 事务

    1.1.20 union、union all

    1.1.21 时间相关

    1.1.22 临时表

    1.1.23 视图

    1.1.24 存储过程

    1.1.25 触发器

    1.2 扩展资料

    1.2.1 数据操纵语言(DML)

    1.2.2 数据定义语言(DDL)

    1.2.3 数据控制语言(DCL)

    1.3 pymysql

    1.3.1 安装pymysql

    1.3.2 pymysql.connect()连接数据库函数

    1.3.3 conn.cursor():获取游标

    1.3.4 执行sql语句execute和executemany

    1.3.5 创建数据库

    1.3.6 创建数据表

    1.3.7 执行单条插入语句

    1.3.8 批量插入多条数据

    1.3.9 查询数据

    1.3.10 更新数据

    1.3.11 删除数据

    1.3.12 数据回滚


    一、数据库

    1.1 基础操作

    1.1.1 连接数据库

    在win-doc窗口中,连接数据库:

    mysql -h127.0.0.1 -uroot -p
    mysql -h127.0.0.1 -uroot -p123456
    mysql -hlocalhost -uroot -p

    1.1.2 指定端口

    mysql -hlocalhost -uroot -P3306 -p

    1.1.3 mysql授权语句

    1. # 此语句适用于mysql5版本,若你装的是mysql8.0高版本,这样使用会报错
    2. GRANT ALL PRIVILEGES ON test.* TO 'abuser'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
    3. # 报错原因:高版本数据库把创建用户和赋予权限分开了,所以高版本数据库应该按照如下步骤创建用户并授权
    4. create user 'lappin'@'%' identified by '123456';
    5. GRANT ALL PRIVILEGES ON test.* TO 'lappin'@'%' WITH GRANT OPTION;
    6. # 刷新
    7. flush privileges;

    说明:
    all  privileges :表示所有的权限 ,增删改查权限全部都有了
    *.*: 所有的数据库下面所有的表,test.*,表示test库下面所有表
    'lifuche'@'%' :test库下面所有表,所有的权限,全部都给lifuche用户  , % 表示lifuche用户可以在任意机器上面进行连接登录
    identified by '123456' :远程登录连接的密码
    WITH GRANT OPTION: 表示该用户可以将自己拥有的权限授权给别人。注意:经常有人在创建操作用户的时候不指定WITH GRANT OPTION选项,导致后来该用户不能使用GRANT命令创建用户或者给其它用户授权。
    flush   privileges:刷新权限列表

    1.1.4 创建数据库

    CREATE DATABASE IF NOT EXISTS test DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

    说明:
    CREATE DATABASE:创建数据库
    IF NOT EXISTS test:如果test库不存在
    DEFAULT CHARSET utf8:默认utf8字符集
    COLLATE utf8_general_ci: COLLATE指规则和限制,utf8_general_ci中的ci指大小写不敏感

    1. mysql> CREATE DATABASE IF NOT EXISTS test DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
    2. Query OK, 1 row affected, 2 warnings (0.02 sec)

    1.1.5 查看数据库

    1. mysql> show databases;
    2. +--------------------+
    3. | Database |
    4. +--------------------+
    5. | information_schema |
    6. | test |
    7. +--------------------+
    8. 2 rows in set (0.00 sec)

    1.1.6 选择数据库&查看你当前使用的数据库

    1. mysql> use test; # 选择数据库test
    2. Database changed
    3. mysql> select database();# 查看你当前用的数据库
    4. +------------+
    5. | database() |
    6. +------------+
    7. | test |
    8. +------------+
    9. 1 row in set (0.00 sec)

    1.1.7 删除数据库 DROP  DATABASE;

    1.1.8 创建表

    1. mysql> show tables;
    2. Empty set (0.03 sec)
    3. mysql> create table user(id int(10) primary key auto_increment,name varchar(20));
    4. Query OK, 0 rows affected, 1 warning (0.05 sec)
    5. mysql> show tables;
    6. +----------------+
    7. | Tables_in_test |
    8. +----------------+
    9. | user |
    10. +----------------+
    11. 1 row in set (0.01 sec)

    1.1.9 插入表数据&查询表数据

    1. mysql> insert into user(id,name) values(1,"张三");
    2. Query OK, 1 row affected (0.02 sec)
    3. mysql> insert into user(name) values("李四"); # id是自增的,可省略不写
    4. Query OK, 1 row affected (0.01 sec)
    5. mysql> insert into user values(3,"王老师"); # 前面省略字段名时,values中每个字段值都要写
    6. Query OK, 1 row affected (0.01 sec)
    7. mysql> insert into user values(4,"吴老师"),(5,"小明"),(6,"王五");# 插入多行数据
    8. Query OK, 3 rows affected (0.01 sec)
    9. Records: 3 Duplicates: 0 Warnings: 0
    10. mysql> select * from user;
    11. +----+--------+
    12. | id | name |
    13. +----+--------+
    14. | 1 | 张三 |
    15. | 2 | 李四 |
    16. | 3 | 王老师 |
    17. | 4 | 吴老师 |
    18. | 5 | 小明 |
    19. | 6 | 王五 |
    20. +----+--------+
    21. 6 rows in set (0.01 sec)

    1.1.10 删除表数据

    1. mysql> delete from user where id = 1;
    2. Query OK, 1 row affected (0.01 sec)
    3. mysql> select * from user;
    4. +----+--------+
    5. | id | name |
    6. +----+--------+
    7. | 2 | 李四 |
    8. | 3 | 王老师 |
    9. | 4 | 吴老师 |
    10. | 5 | 小明 |
    11. | 6 | 王五 |
    12. +----+--------+
    13. 5 rows in set (0.00 sec)

    1.1.11 更新表数据

    1. mysql> update user set name="赵小明",id=10 where id = 5;
    2. Query OK, 1 row affected (0.01 sec)
    3. Rows matched: 1 Changed: 1 Warnings: 0
    4. mysql> select * from user;
    5. +----+--------+
    6. | id | name |
    7. +----+--------+
    8. | 2 | 李四 |
    9. | 3 | 王老师 |
    10. | 4 | 吴老师 |
    11. | 6 | 王五 |
    12. | 10 | 赵小明 |
    13. +----+--------+
    14. 5 rows in set (0.00 sec)

     

    1.1.12 删除所有表数据

    1)delete from user;

    2)truncate table user;

    1.1.13 删除表数据及表结构

    drop table user;

    删除表字段

     alter table 表名 drop 字段名;

     alter table studentinfo drop status; 

    1.1.14 delete、truncate、drop的区别

    参考:drop、truncate和delete的区别_青青angle的博客-CSDN博客_truncate和delete的区别

    1.1.15 查看是否设置自动提交

    MySQL默认操作模式就是autocommit=1自动提交模式。这就表示除非显式地开始一个事务,否则每个查询都被当做一个单独的事务自动执行。

    1. mysql> show variables like "autocommit";
    2. +---------------+-------+
    3. | Variable_name | Value |
    4. +---------------+-------+
    5. | autocommit | ON |
    6. +---------------+-------+
    7. 1 row in set, 1 warning (0.01 sec)

    参考:关于mysql的参数autocommit_三斤和他的朋友们的博客-CSDN博客_autocommit

    autocommit变量验证:

    第一步:先在客户端A中执行

    1. mysql> show variables like "autocommit";
    2. +---------------+-------+
    3. | Variable_name | Value |
    4. +---------------+-------+
    5. | autocommit | ON |
    6. +---------------+-------+
    7. 1 row in set, 1 warning (0.01 sec)
    8. mysql> select * from user;
    9. +----+------+
    10. | id | name |
    11. +----+------+
    12. | 1 | 一小 |
    13. +----+------+
    14. 1 row in set (0.00 sec)

    第二步:从客户端B查询表数据

    第三步:然后在客户端A中执行

    1. mysql> insert into user values(2,"小明");
    2. Query OK, 1 row affected (0.01 sec)

    第四步: 在客户端A中设置autocommit = 0,并插入一条新纪录,但不commit

    1. mysql> set autocommit = 0;
    2. Query OK, 0 rows affected (0.00 sec)
    3. mysql> show variables like "autocommit";
    4. +---------------+-------+
    5. | Variable_name | Value |
    6. +---------------+-------+
    7. | autocommit | OFF |
    8. +---------------+-------+
    9. 1 row in set, 1 warning (0.00 sec)
    10. mysql> insert into user values(3,"小张");
    11. Query OK, 1 row affected (0.00 sec)

    第五步: 在客户端A中commit

    1. mysql> commit;
    2. Query OK, 0 rows affected (0.01 sec)

    总结:

    设定了autocommit=1后,所有的内容都被自动commit,除非写了begin,begin后的内容需要单独再commit一次才可以。
    设定了autocommit=0后,所有的操作都需要commit后才会生效
    如果2个终端尝试修改同一行数据,且都没有commit,第二个修改的终端则会卡死,等待第一次修改的commit。 

    1.1.16 查看表创建的语句

    show create table user;

    1. mysql> show create table user;
    2. +-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
    3. | Table | Create Table |
    4. +-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
    5. | user | CREATE TABLE `user` (
    6. `id` int NOT NULL AUTO_INCREMENT,
    7. `name` varchar(20) DEFAULT NULL,
    8. PRIMARY KEY (`id`)
    9. ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb3 |
    10. +-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
    11. 1 row in set (0.01 sec)
    12. mysql> show create table user \G;
    13. *************************** 1. row ***************************
    14. Table: user
    15. Create Table: CREATE TABLE `user` (
    16. `id` int NOT NULL AUTO_INCREMENT,
    17. `name` varchar(20) DEFAULT NULL,
    18. PRIMARY KEY (`id`)
    19. ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb3
    20. 1 row in set (0.01 sec)
    21. ERROR:
    22. No query specified

    1.1.17 查看表字段信息

    desc user;

    1. mysql> desc user;
    2. +-------+-------------+------+-----+---------+----------------+
    3. | Field | Type | Null | Key | Default | Extra |
    4. +-------+-------------+------+-----+---------+----------------+
    5. | id | int | NO | PRI | NULL | auto_increment |
    6. | name | varchar(20) | YES | | NULL | |
    7. +-------+-------------+------+-----+---------+----------------+
    8. 2 rows in set (0.02 sec)

    1.1.18 添加/删除表索引

    ALTER TABLE `userADD INDEX name_index(`name`);

    ALTER TABLE user ADD INDEX name_index(name);

    注意:` 不是单引号,但可以直接不加这个符号

    1. mysql> ALTER TABLE `user` ADD INDEX name_index(`name`);
    2. Query OK, 0 rows affected (0.06 sec)
    3. Records: 0 Duplicates: 0 Warnings: 0
    4. mysql> desc user; # key= MUL,表示一个普通索引
    5. +-------+-------------+------+-----+---------+----------------+
    6. | Field | Type | Null | Key | Default | Extra |
    7. +-------+-------------+------+-----+---------+----------------+
    8. | id | int | NO | PRI | NULL | auto_increment |
    9. | name | varchar(20) | YES | MUL | NULL | |
    10. +-------+-------------+------+-----+---------+----------------+
    11. 2 rows in set (0.00 sec)

    删除索引:ALTER TABLE `user` drop INDEX name_index;

    1. mysql> ALTER TABLE `user` drop INDEX name_index;# 删除索引
    2. Query OK, 0 rows affected (0.02 sec)
    3. Records: 0 Duplicates: 0 Warnings: 0
    4. mysql> desc user;
    5. +-------+-------------+------+-----+---------+----------------+
    6. | Field | Type | Null | Key | Default | Extra |
    7. +-------+-------------+------+-----+---------+----------------+
    8. | id | int | NO | PRI | NULL | auto_increment |
    9. | name | varchar(20) | YES | | NULL | |
    10. +-------+-------------+------+-----+---------+----------------+
    11. 2 rows in set (0.00 sec)

    1.1.19 事务

    1. mysql> create table test_transaction(id int);
    2. Query OK, 0 rows affected (0.05 sec)
    3. mysql> begin; # 开始事务
    4. Query OK, 0 rows affected (0.00 sec)
    5. mysql> insert into test_transaction values(1);
    6. Query OK, 1 row affected (0.00 sec)
    7. mysql> insert into test_transaction values(2);
    8. Query OK, 1 row affected (0.00 sec)
    9. mysql> select * from test_transaction;
    10. +------+
    11. | id |
    12. +------+
    13. | 1 |
    14. | 2 |
    15. +------+
    16. 2 rows in set (0.00 sec)
    17. mysql> rollback; # 回滚
    18. Query OK, 0 rows affected (0.01 sec)
    19. mysql> select * from test_transaction; # 此时表内容被清空
    20. Empty set (0.00 sec)
    21. mysql> begin; # 开始事务
    22. Query OK, 0 rows affected (0.00 sec)
    23. mysql> insert into test_transaction values(1);
    24. Query OK, 1 row affected (0.01 sec)
    25. mysql> insert into test_transaction values(2);
    26. Query OK, 1 row affected (0.01 sec)
    27. mysql> select * from test_transaction;
    28. +------+
    29. | id |
    30. +------+
    31. | 1 |
    32. | 2 |
    33. +------+
    34. 2 rows in set (0.00 sec)
    35. mysql> commit; # 提交事务
    36. Query OK, 0 rows affected (0.00 sec)
    37. mysql> select * from test_transaction;
    38. +------+
    39. | id |
    40. +------+
    41. | 1 |
    42. | 2 |
    43. +------+
    44. 2 rows in set (0.00 sec)
    45. mysql> rollback; # 提交事务后再回滚,不影响表内容
    46. Query OK, 0 rows affected (0.00 sec)
    47. mysql> select * from test_transaction;
    48. +------+
    49. | id |
    50. +------+
    51. | 1 |
    52. | 2 |
    53. +------+
    54. 2 rows in set (0.00 sec)

    1.1.20 union、union all

    用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

    1. mysql> select id from studentinfo union select id from grade;
    2. +----+
    3. | id |
    4. +----+
    5. | 1 |
    6. | 2 |
    7. | 3 |
    8. | 4 |
    9. | 5 |
    10. +----+
    11. 5 rows in set (0.00 sec)
    12. mysql> select id from studentinfo union all select id from grade;
    13. +----+
    14. | id |
    15. +----+
    16. | 1 |
    17. | 2 |
    18. | 3 |
    19. | 4 |
    20. | 1 |
    21. | 2 |
    22. | 3 |
    23. | 4 |
    24. | 5 |
    25. +----+
    26. 9 rows in set (0.00 sec)

    1.1.21 时间相关

    1. mysql> select now(); # 当前时间
    2. +---------------------+
    3. | now() |
    4. +---------------------+
    5. | 2022-06-27 16:40:36 |
    6. +---------------------+
    7. 1 row in set (0.00 sec)
    8. mysql> select date_sub(now(),interval 2 day);# 日期减法
    9. +--------------------------------+
    10. | date_sub(now(),interval 2 day) |
    11. +--------------------------------+
    12. | 2022-06-25 16:42:00 |
    13. +--------------------------------+
    14. 1 row in set (0.01 sec)
    15. mysql> select date_add(now(),interval 2 day);# 日期加法
    16. +--------------------------------+
    17. | date_add(now(),interval 2 day) |
    18. +--------------------------------+
    19. | 2022-06-29 16:42:11 |
    20. +--------------------------------+
    21. 1 row in set (0.00 sec)
    22. mysql> select curdate();# 当前日期
    23. +------------+
    24. | curdate() |
    25. +------------+
    26. | 2022-06-27 |
    27. +------------+
    28. 1 row in set (0.01 sec)

    1.1.22 临时表

    1. mysql> create TEMPORARY table testxx(id int(10));
    2. Query OK, 0 rows affected, 1 warning (0.01 sec)

    1.1.23 视图

    1. mysql> create view tv as select * from grade;
    2. Query OK, 0 rows affected (0.01 sec)
    3. mysql> select * from tv;
    4. +----+----------+----------+-------+
    5. | ID | stuID | course | score |
    6. +----+----------+----------+-------+
    7. | 1 | 20220101 | computer | 100 |
    8. | 2 | 20220101 | hr | 90 |
    9. | 3 | 20220101 | history | 80 |
    10. | 4 | 20220102 | history | 60 |
    11. | 5 | 20220102 | music | 70 |
    12. +----+----------+----------+-------+
    13. 5 rows in set (0.00 sec)
    14. mysql> insert into grade values(6,20220104,"computer",50);
    15. Query OK, 1 row affected (0.01 sec)
    16. mysql> select * from tv; # 视图也被更新
    17. +----+----------+----------+-------+
    18. | ID | stuID | course | score |
    19. +----+----------+----------+-------+
    20. | 1 | 20220101 | computer | 100 |
    21. | 2 | 20220101 | hr | 90 |
    22. | 3 | 20220101 | history | 80 |
    23. | 4 | 20220102 | history | 60 |
    24. | 5 | 20220102 | music | 70 |
    25. | 6 | 20220104 | computer | 50 |
    26. +----+----------+----------+-------+
    27. 6 rows in set (0.00 sec)

    1.1.24 存储过程

    1. # 创建存储过程
    2. delimiter //
    3. create procedure createDatas()
    4. begin
    5. set @i = 100;
    6. set @n = 200;
    7. while @i <= @n do
    8. set @student_id = concat("202206",@i);
    9. set @name = concat("Parmley",@i);
    10. set @sex = "男";
    11. set @tel = concat("18",right(rand(),9));
    12. set @AdmissionDate = date_sub(now(),interval floor(rand()*50) day);
    13. insert into studentinfo(student_id,name,sex,tel,AdmissionDate) values(@student_id,@name,@sex,@tel,@AdmissionDate);
    14. set @course_one = "python";
    15. set @course_two = "java";
    16. set @score = floor(70 + rand()*30);
    17. insert into grade(stuID,course,score) values(@student_id,@course_one,@score);
    18. insert into grade(stuID,course,score) values(@student_id,@course_two,@score);
    19. set @i = @i + 1;
    20. end while;
    21. end //
    22. delimiter ;
    23. # 调用存储过程
    24. call createDatas();
    25. # 删除存储过程
    26. drop procedure createDatas;

    说明:

    1. delimiter是mysql分隔符,在mysql客户端中分隔符默认是分号";",delimiter //表示把mysql分隔符定义为//。
    其实就是告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。 如果一次输入的语句较多,并且语句中间有分号,这时需要新指定一个特殊的分隔符
    2. create procedure createDatas():创建存储过程
    3. concat(s1,s2...):连接字符串
    4. rand(seed):随机生成一个>=0且<1的小数
    5. right(str,len):从给定字符串str的右侧T恤指定长度len的字符。
    len:要提取的字符数。如果此参数大于字符串中的字符数,则此函数将返回实际的字符串。
    6. floor():向下取整函数,如floor(2.6)=2
    7. data_sub(date,INTERVAL expr type):从日期date减去指定的时间间隔

    1.1.25 触发器

    1.2 扩展资料

    参考SQL语言的3种分类_灰太狼_cxh的博客-CSDN博客_sql语言的分类

    SQL语言按照实现的功能不同,主要分为3类:数据操纵语言(DML),数据定义语言(DDL),数据控制语言(DCL)。

    1.2.1 数据操纵语言(DML)

    主要用来处理数据库中的数据内容。允许用户对数据库中的数据进行查询 ,插入,更新和删除等操作。DML操作是可以手动控制事务的开启、提交和回滚的

    常用的DML语句及其功能:

    DML语句功能说明
    SELECT从表或视图中检索数据行
    INSERT插入数据到表或视图
    UPDATE更新数据
    DELETE删除数据
    CALL调用过程
    MERGE合并(插入或修改)
    COMMIT将当前事务所做的更改永久化(写入数据库)
    ROLLBACK取消上次提交以来的所有操作


    1.2.2 数据定义语言(DDL)

    是一组SQL命令,用于创建和定义数据库对象(管理数据库对象),并且将对这些对象的定义保存到数据字典中。通过DDL语句可以创建数据库对象,修改数据库对象和删除数据库对象等。

    常用的DDL语句及其功能:

    DDL语句功能说明
    CREATE创建数据库结构
    ALTER修改数据库结构
    DROP删除数据库结构
    RENAME更改数据库对象的名称
    TRUNCATE删除表的全部内容

    注:每一条DDL语句执行后,Oracle都将提交当前事务。DDL操作是隐性提交的,不能rollback

    1.2.3 数据控制语言(DCL)

    数据控制语言用于修改数据库结构的操作权限。DCL语句主要有2种:

    DCL常用语句及其功能:

    DCL语句功能说明
    CRANT授予其他用户对数据库结构的访问权限
    REVOKE收回用户访问数据库结构的权限

    1.3 pymysql

    数据库操作流程:
    1、pymysql.connect建立链接,成功获取了conn对象
    2、设定使用的数据库,select_db方法
    3、获取游标cur = conn.cursor()
    4、拼sql
    5、cur.execute(sql语句),cur.fetchmany(sql模板字符串,[包含多组数据])
    6、关闭游标:cur.close()
    7、提交事务:conn.commit()
    8、关闭连接:conn.close()

    1. import pymysql
    2. import random
    3. def insertData():
    4. conn = pymysql.connect(
    5. host = "127.0.0.1",
    6. port = 3306,
    7. user = "root",
    8. passwd = "123456",
    9. # db = "test",
    10. charset = "utf8")
    11. cur = conn.cursor()
    12. conn.select_db('test')
    13. courseList = ['python', 'java', 'mysql', 'linux', '接口测试', '性能测试', '自动化测试','数据结构与算法']
    14. for i in range(1, 101):
    15. student_id = '201803' + '0' * (3 - len(str(i))) + str(i)
    16. name = random.choice(['Lucy','Tom','Lily','Amy','Dave','Aaron','Baron']) + str(i)
    17. tel = '1' + str(random.choice([3, 5, 7, 8])) + str(random.random())[2:11]
    18. sex = random.choice(['女', '男'])
    19. stuinfo_sql = "insert into studentInfo(student_id, name, sex, tel, AdmissionDate) \
    20. values('%s', '%s', '%s', '%s', date_sub(now(),interval %s day))" \
    21. %(student_id, name, sex, tel, random.randint(90, 120))
    22. cur.execute(stuinfo_sql)
    23. conn.commit()
    24. for j in courseList:
    25. grade_sql = "insert into grade(stuID,course,score) values('%s','%s',%s)" %(student_id,j,random.randint(80, 100))
    26. cur.execute(grade_sql)
    27. cur.close()
    28. conn.commit()
    29. conn.close()
    30. insertData()
    31. print("数据插入结束! ")

    1.3.1 安装pymysql

    py -3 -m pip install pymysql

    1.3.2 pymysql.connect()连接数据库函数

    1. #coding=utf-8
    2. import pymysql
    3. # 打开数据库连接
    4. conn = pymysql.connect(
    5. host = "127.0.0.1",
    6. port = 3306,
    7. user = "root",
    8. passwd = "123456",
    9. db = "test",
    10. charset = "utf8")
    11. print(conn)
    12. print(type(conn))

    1.3.3 conn.cursor():获取游标

    要想操作数据库,光连接数据库是不够的,必须拿到操作数据库的游标,才能进行后续的操作,比如读取数据、添加数据。通过获取到的数据库连接实例conn下的cursor()方法来创建游标。游标用来接收返回结果

    1. #coding=utf-8
    2. import pymysql
    3. # 打开数据库连接
    4. conn = pymysql.connect(
    5. host = "127.0.0.1",
    6. port = 3306,
    7. user = "root",
    8. passwd = "123456",
    9. db = "test",
    10. charset = "utf8")
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. print(cursor)
    14. print(type(cursor))

    1.3.4 执行sql语句execute和executemany

    • execute(query,args=None)

    函数作用:执行单条的sql语句,执行成功后返回受影响的行数
    参数说明:
    query:要执行的sql语句,字符串类型
    args:可选的序列或映射,用于query的参数值。如果args为序列,query中必须使用%s做占位符;如果args为映射,query中必须使用%(key)s做占位符

    • executemany(query,args=None)

    函数作用:批量执行sql语句,比如批量插入数据,执行成功后返回受影响的行数
    参数说明:
    query:要执行的sql语句,字符串类型
    args:嵌套的序列或映射,用于query的参数值

    注意:
    1.数据库性能瓶颈很大一部份就在于网络IO和磁盘IO,将多个sql语句放在一起,只执行一次IO,可以有效的提升数据库性能。推荐此方法
    2.用executemany()方法一次性批量执行sql语句,固然很好,但是当数据一次传入过多到server端,可能造成server端的buffer溢出,也可能产生一些意想不到的麻烦。所以,合理、分批次使用executemany是个合理的办法

    1.3.5 创建数据库

    1. #coding=utf-8
    2. import pymysql
    3. # 创建数据库
    4. try:
    5. conn = pymysql.connect(
    6. host = "127.0.0.1",
    7. port = 3306,
    8. user = "root",
    9. passwd = "123456",
    10. )
    11. cur =conn.cursor()
    12. cur.execute("create database if not exists pythonDB default charset utf8 collate utf8_general_ci")
    13. cur.close()
    14. print("创建数据库pythonDB成功!")
    15. except pymysql.Error as e:
    16. print("Mysql Error %d:%s" %(e.args[0],e.agrs[1]))

    1.3.6 创建数据表

    1. #coding=utf-8
    2. import pymysql
    3. try:
    4. conn = pymysql.connect(
    5. host = "127.0.0.1",
    6. port = 3306,
    7. user = "root",
    8. passwd = "123456"
    9. )
    10. conn.select_db('pythondb')# 选择pythonDB数据库
    11. cur = conn.cursor()# 获取游标
    12. # 如果所建表已存在,删除重建
    13. cur.execute("drop table if exists User;")
    14. # 执行建表sql语句
    15. cur.execute('''CREATE TABLE `User`(
    16. `id` int(11) DEFAULT NULL,
    17. `name` varchar(255) DEFAULT NULL,
    18. `password` varchar(255) DEFAULT NULL,
    19. `birthday` date DEFAULT NULL
    20. )ENGINE=innodb DEFAULT CHARSET=utf8;''')
    21. cur.close()
    22. conn.close()
    23. print("创建数据表成功!")
    24. except pymysql.Error as e:
    25. print("Mysql Error %d: %s" %(e.args[0], e.args[1]))

    1.3.7 执行单条插入语句

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. # 插入一条数据
    14. insert = cursor.execute("insert into user values(1,'Tom','123','1990-01-01')")
    15. print("添加语句受影响的行数: ", insert)
    16. # 另一种插入数据方法,通过格式字符串传入值,此方式可以防止sql注入
    17. sql = "insert into user values(%s, %s, %s, %s)"
    18. insert = cursor.execute(sql, (3,'lucy','efg','1993-02-01'))
    19. print("添加语句受影响的行数: ", insert)
    20. # 关闭游标
    21. cursor.close()
    22. # 提交事务
    23. conn.commit()
    24. # 关闭数据库连接
    25. conn.close()
    26. print("sql语句执行成功! ")

     

     

    1.3.8 批量插入多条数据

    1. #coding=utf-8
    2. import pymysql
    3. import random
    4. import time
    5. def now():
    6. return time.strftime("%Y-%m-%d")
    7. conn = pymysql.connect(
    8. host = "127.0.0.1",
    9. port = 3306,
    10. user = "root",
    11. passwd = "123456" ,
    12. db = "pythondb",
    13. charset = "utf8"
    14. )
    15. # 使用cursor()方法获取数据库的操作游标
    16. cursor = conn.cursor()
    17. for i in range(10,20):
    18. # 另一种插入数据方法,通过格式字符串传入值,此方式可以防止sql注入
    19. sql = "insert into user values(%s, %s, %s, %s)"
    20. cursor.execute(sql,(random.randint(1,10000),'lucy'+str(random.randint(1,10000)),'efg'+str(random.randint(1,10000)),now()))
    21. # 关闭游标
    22. cursor.close()
    23. # 提交事务
    24. conn.commit()
    25. # 关闭数据库连接
    26. conn.close()
    27. print("sql语句执行成功! ")

    使用executemany插入多条数据:

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. #批量插入条数据
    14. sql = "insert into user values(%s, %s, %s, %s)"
    15. insert = cursor.executemany(sql, [
    16. (5,'tom','tom','1989-03-17'),
    17. (6,'amy','test','1898-12-01'),
    18. (7,'lily','linux','1994-06-23')])
    19. print("批量插入返回受影响的行数: ", insert)
    20. # 关闭游标
    21. cursor.close()
    22. # 提交事务
    23. conn.commit()
    24. # 关闭数据库连接
    25. conn.close()
    26. print("sql语句执行成功! ")

     

     

    1.3.9 查询数据

    使用execute()函数得到的只是受影响的行数,并不能真正拿到查询的内容。cursor对象还提供了3种提取数据的方法:fetchone、fetchmany、fetchall.。每个方法都会导致游标动,所以必须注意游标的位置。

    cursor.fetchone():获取游标所在处的一行数据,返回元组,没有返回None
    cursor.fetchmany(size):接受size行返回结果行。如果size大于返回的结果行的数量,则会返回cursor.arraysize条数据;不传size时,size=1
    cursor. fetchall():接收全部的返回结果行

    1. 使用fetchone()读取数据:

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. while 1:
    15. res = cursor.fetchone()
    16. if res is None:
    17. # 表示已经取完结果集
    18. break
    19. print(res)
    20. #将读取到的时间格式化
    21. print(res[-1].strftime("%Y-%m-%d"))
    22. # 关闭游标
    23. cursor.close()
    24. # 提交事务
    25. conn.commit()
    26. # 关闭数据库连接
    27. conn.close()
    28. print("sql语句执行成功! ")

    2. 使用fetchmany()读取数据:

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. # 获取游标处两条数据
    15. resTuple = cursor.fetchmany(2)
    16. print("结果集类型:",type(resTuple))
    17. for i in resTuple:
    18. print(i)
    19. # 关闭游标
    20. cursor.close()
    21. # 提交事务
    22. conn.commit()
    23. # 关闭数据库连接
    24. conn.close()
    25. print("sql语句执行成功! ")

    3. 使用fetchall()读取数据:

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. # 获取游标处两条数据
    15. resSet = cursor.fetchall()
    16. print("共%s条数据:"%len(resSet))
    17. print(resSet)
    18. # 关闭游标
    19. cursor.close()
    20. # 提交事务
    21. conn.commit()
    22. # 关闭数据库连接
    23. conn.close()
    24. print("sql语句执行成功! ")

    1.3.10 更新数据

    1. 更新单条数据

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. update = cursor.execute("update user set password = 'Tom_test' where name = 'Tom'")
    14. print("修改语句受影响的行数:",update)
    15. # 查询一条数据
    16. cursor.execute("select * from user where name = 'Tom'")
    17. print(cursor.fetchone())
    18. # 关闭游标
    19. cursor.close()
    20. # 提交事务
    21. conn.commit()
    22. # 关闭数据库连接
    23. conn.close()
    24. print("sql语句执行成功! ")

    2. 批量更新数据

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. #查询一条数据
    14. query = cursor.execute("select * from user")
    15. print("表中所有数据: ")
    16. for i in cursor.fetchall():
    17. print(i)
    18. # 批量更新数据
    19. cursor.executemany("update user set password = %s where name=%s", [('tomx2x', 'tom'),('Tomx2x', 'amy')])
    20. # 查看更新后的结果
    21. query = cursor.execute("select * from user")
    22. print("表中所有数据: ")
    23. for i in cursor.fetchall():
    24. print(i)
    25. # 关闭游标
    26. cursor.close()
    27. # 提交事务
    28. conn.commit()
    29. # 关闭数据库连接
    30. conn.close()
    31. print("sql语句执行成功! ")

    1.3.11 删除数据

    1. 删除单条数据

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. print("表中所有数据: ")
    15. for i in cursor.fetchall():
    16. print(i)
    17. # 删除数据
    18. delete = cursor.execute("delete from user where name='tom'")
    19. print("删除语句影响的行数: ", delete)
    20. print("删除一条数据后,表中数据: ")
    21. cursor.execute("select * from user")
    22. for i in cursor.fetchall():
    23. print(i)
    24. # 关闭游标
    25. cursor.close()
    26. # 提交事务
    27. conn.commit()
    28. # 关闭数据库连接
    29. conn.close()
    30. print("sql语句执行成功! ")

    2. 批量删除数据

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. print("表中所有数据: ")
    15. for i in cursor.fetchall():
    16. print(i)
    17. # 批量删除数据
    18. delete = cursor.executemany("delete from user where name=%s", [('amy',), ('lily',)])
    19. print("删除语句影响的行数: ", delete)
    20. print("删除一条数据后,表中数据: ")
    21. cursor.execute("select * from user")
    22. for i in cursor.fetchall():
    23. print(i)
    24. # 关闭游标
    25. cursor.close()
    26. # 提交事务
    27. conn.commit()
    28. # 关闭数据库连接
    29. conn.close()
    30. print("sql语句执行成功! ")

    1.3.12 数据回滚

    1. #coding=utf-8
    2. import pymysql
    3. conn = pymysql.connect(
    4. host = "127.0.0.1",
    5. port = 3306,
    6. user = "root",
    7. passwd = "123456" ,
    8. db = "pythondb",
    9. charset = "utf8"
    10. )
    11. # 使用cursor()方法获取数据库的操作游标
    12. cursor = conn.cursor()
    13. cursor.execute("select * from user")
    14. datas = cursor.fetchall()
    15. print("修改前的数据: \n", datas[0])
    16. # 更新数据表中第一条数据
    17. cursor.execute("update user set birthday='2100-08-12' where name='lucy'")
    18. cursor.execute("select * from user")
    19. datas = cursor.fetchall()
    20. print("修改后的数据: \n", datas[0])
    21. # 回滚事务
    22. conn.rollback()
    23. cursor.execute("select * from user")
    24. datas = cursor.fetchall()
    25. print("事务回滚后的数据: \n", datas[0])
    26. # 关闭游标
    27. cursor.close()
    28. # 提交事务
    29. conn.commit()
    30. # 关闭数据库连接
    31. conn.close()
    32. print("sql语句执行成功! ")

    练习:多线程并发,性能测试程序

    1. import pymysql
    2. import os
    3. import random
    4. from multiprocessing.managers import BaseManager
    5. from multiprocessing import Pool
    6. def createTable():
    7. conn = pymysql.connect(
    8. host = "localhost",
    9. port = 3306,
    10. user = "root",
    11. passwd = "123456")
    12. cur = conn.cursor()
    13. sql_database = 'CREATE DATABASE IF NOT EXISTS userinfo DEFAULT CHARSET utf8 COLLATE utf8_general_ci;'
    14. sql_table = '''create table student(
    15. ID int not null auto_increment comment "不为空的自增长的主键ID",
    16. name varchar(30) not null,
    17. age int default 0,
    18. email varchar(40),
    19. tel varchar(13) unique not null,
    20. primary key (ID)
    21. )engine=innodb character set utf8 comment "表注释";
    22. '''.encode("utf-8")
    23. try:
    24. # 建库
    25. cur.execute(sql_database)
    26. conn.select_db('userinfo')
    27. cur.execute("drop table if exists student;")
    28. # 建表
    29. cur.execute(sql_table)
    30. except Exception as e:
    31. print(e)
    32. else:
    33. print("数据库及数据表创建成功! ")
    34. cur.close()
    35. conn.commit()
    36. conn.close()
    37. class myMySQL(object):
    38. def __init__(self):
    39. # 打开数据库连接
    40. self.conn = pymysql.connect(
    41. host = "localhost",
    42. port = 3306,
    43. user = "root",
    44. passwd = "123456",
    45. db = "userinfo",
    46. charset = "utf8")
    47. # 使用cursor()方法获取数据库的操作游标
    48. self.cur = self.conn.cursor()
    49. def executeSql(self, sql) :
    50. print(sql)
    51. try:
    52. res = self.cur.execute(sql)
    53. print("sql end ", res)
    54. self.conn.commit()
    55. except:
    56. traceback.print_exc()
    57. def quit(self):
    58. print("quit====")
    59. self.cur.close()
    60. self.conn.commit()
    61. self.conn.close()
    62. class MyManager(BaseManager): pass
    63. def my_Manager():
    64. m = MyManager()
    65. m.start()
    66. return m
    67. # 将myMySQL类注册到MyManager管理类中
    68. MyManager.register('myMySQL', myMySQL)
    69. # print("----", MyManager.__dict__)
    70. def run(my_sql):
    71. print("subprocesses is", os.getpid())
    72. # 造数据
    73. name = 'Amy' + str(random.randint(1, 100)) + '_' + str(os.getpid())
    74. age = random.randint(1, 100)
    75. email = name + '@qq.com'
    76. tel = '1' + str(random.choice([3, 5, 7, 8])) + str(random.random())[2:11]
    77. sql = 'insert into student(name, age, email, tel) values("%s", "%s", "%s", "%s")' %(name, age, email, tel)
    78. #插入数据
    79. my_sql.executeSql(sql)
    80. if __name__ == '__main__':
    81. createTable()
    82. #创建进程共享数据对象
    83. manager = my_Manager()
    84. #因为myMySQL类注册到MyManager管理类中,所以可以使用如下语句创建共享对象中的myMySQL实例对象,在不同进程间调用
    85. my_sql = manager.myMySQL()
    86. # print("111", my_sql)
    87. print('Parent process %s.' % os.getpid())
    88. p = Pool(os.cpu_count())
    89. n = 100
    90. while n:
    91. p.apply(run, args = (my_sql,)) #每调用一次此方法会生成一个进程,最多生成和cpu盒数相当的进程
    92. n -= 1
    93. print('Waiting for all subprocesses done...')
    94. p.close()
    95. p.join()
    96. print('All subprocesses done.')
    97. my_sql.quit()

  • 相关阅读:
    HTTP协议和HTTPS协议
    openvswitch学习
    Linux 执行 shell 报错 $‘\r‘ 的解决办法
    [大模型]QAnything纯Python环境安装教程
    解决 cocos2d-x-4.0 IOS构建出错的问题—执行命令出错,返回值:65
    #力扣:LCP 06. 拿硬币@FDDL
    java计算机毕业设计疆域特色农家乐系统源码+mysql数据库+系统+lw文档+部署
    Python数据可视化基础:使用Matplotlib绘制图表
    长尾关键词-长尾关键词的作用-长尾关键词挖掘软件
    【相机坐标系、ORB_SLAM2坐标系】
  • 原文地址:https://blog.csdn.net/qq_22895113/article/details/125479774