MySQL_Ch7

@BCKou

MySQL_Ch7

#1、权限
#登录root用户

#创建用户
create user ‘用户名’@‘主机名’ identified by ‘密码’;
#localhost 本地主机 — 127.0.0.1(本地地址、回环地址)
具体ip
#用户名 : 自己创建的用户名字,随意取,但是不要是中文
#主机名:指定该用户在哪个主机上可以登录,

如果是本地用户可以用localhost,如果想让该用户从指定远程电脑上登录,

可以使用通配符%

#密码:登录密码,密码可以为空,登录的时候是不需要添加密码信息的

#在只能在localhost这个服务器登录mysql的服务器
create user ‘user1’@‘localhost’ identified by ‘123’;

#在任何电脑上都可以登录mysql的服务器
create user ‘user2’@’%’ identified by ‘123’;

#给用户授权(复杂的)
#用户创建之后,没有什么权限的,需要管理员重新授予权限
#语法格式
#grant 权限1,权限2,… on 数据库名.表名 to ‘用户名’@‘主机名’

#权限:create、alter、select、insert、update等等,

如果权限最大,可以使用all

数据库名.表名:该用户可以操作哪个数据库的哪些表,
#如果要授予该用户对所有的数据库和表都有相应的操作可以写成*.*
'用户名'@'主机名'给哪个用户授权

grant create,alter,insert,update,select
on . to ‘user1’@‘localhost’;

grant all
on . to ‘user2’@’%’;

#撤销权限
#revoke 权限1,权限2,… on 数据库名.表名 from ‘用户名’@‘主机名’
revoke all
on . from ‘user1’@‘localhost’;

#查看权限
show grants for ‘user2’@’%’;
show grants for ‘user1’@‘localhost’;
show grants for ‘root’@‘localhost’;

#删除用户
#格式:drop user ‘用户名’@‘主机名’;
drop user ‘user1’@‘localhost’;

#修改管理员密码
#mysqladmin -uroot -p password 新密码
#注意:需要在未登录mysql的情况下操作,新密码不需要加引号的

#修改普通用户
set password for ‘用户名’@‘主机名’ = password(‘新密码’);
#注意:需要登录mysql的情况下操作
set password for ‘user2’@’%’ = password(‘123456’);

#多个新表
#1)找主键和外键 第一列和最后一列(大概率是外键)
#2)中间表 除了第一列其他列都是外键
#3)意义相同的列(列名不同)
#4)列名含义
#5)有没有层次关系

#综合练习:
#1、查询所有学生的姓名,年龄(显示整数,24.75,按照24显示),
#所学的专业名称,所属的班级名称
#查询的结果、数据来源
select s.STU_NAME,(year(curdate()) - year(s.STU_BIRTHDAY)),
m.major_name, sc.class_name
from student s, major m, sclass sc
where s.STU_MAJOR = m.MAJOR_ID
and s.STU_CLASS = sc.CLASS_ID;

#2、查询专业编号,专业名称,专业人数
select m.MAJOR_ID,m.MAJOR_NAME,count(*)
from student s,major m
where s.STU_MAJOR = m.MAJOR_ID
group by m.MAJOR_ID,m.MAJOR_NAME;

#3、查询班级人数高于各班平均人数的班级编号,班级名称,班级人数

#分组函数在mysql下不能嵌套
select sc.CLASS_ID, sc.CLASS_NAME,count()
from student s,sclass sc
where s.STU_CLASS = sc.CLASS_ID
group by sc.CLASS_ID, sc.CLASS_NAME
having count(
) > any(select avg(t.c)
from student s,(select STU_CLASS,
count(*) as c
from student
group by STU_CLASS) t
group by s.STU_CLASS = t.STU_CLASS);

#分组函数在oracle下可以嵌套
select sc.CLASS_ID, sc.CLASS_NAME,count()
from student s,sclass sc
where s.STU_CLASS = sc.CLASS_ID
group by sc.CLASS_ID, sc.CLASS_NAME
having count(
) > (select avg(count(*))
from student
group by STU_CLASS);

这段 Python 代码可能存在以下问题: 1. 可能是查询结果中没有匹配到任何记录,导致没有进行插入操作。你可以在插入数据之前,先打印出查询结果看一下。 2. 插入数据时使用的参数数量和参数类型与表格定义的不一致。你可以检查表格定义和插入语句参数数量及数据类型是否一致。 3. 插入数据时出现了一些异常,导致事务没有被提交。你可以在插入数据之后,手动提交事务。 改进的代码如下: ```python one_day_ago = datetime.datetime.now() - datetime.timedelta(days=3) # 连接 MongoDB 数据库 mongo_client = pymongo.MongoClient('mongodb://localhost:27017/') mongo_db = mongo_client['testdb'] # 查询 MongoDB 中的数据 result = mongo_db.user_collection.aggregate([ { "$lookup": { "from": "payCondition", "localField": "i_ui_identifier", "foreignField": "userId", "as": "nvc_user_name" } }, { "$match": { "nvc_user_name.addtime": {"$gt": one_day_ago} } } ]) print(list(result)) # 连接 MySQL 数据库 mysql_conn = mysql.connector.connect( host='172.16.2.246', port='33060', user='root', password='8ach4b6f9c', database='testdata_analyse' ) mysql_cursor = mysql_conn.cursor() # 插入数据到 MySQL 数据库 for row in result: var_title = row[0], var_type_name = row[1], var_company_name = row[2], var_source = row[3], var_succees_cause = row[4], is_succeed = row[5], dt_add_time = row[6], var_user_name = row[7] mysql_cursor.execute(""" INSERT INTO t_wuliu_information_pay_statistic VALUES (%s, %s, %s, %s, %s, %s, %s, %s) """, ( var_title, var_type_name, var_company_name, var_source, var_succees_cause, is_succeed, dt_add_time, var_user_name )) mysql_conn.commit() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值