2017-9-14

2017-9-14:笔记

mysqlIDE工具介绍

    生产环境还是推荐mysql命令行,但是为了方便我们个人的测试,可以使用IDE工具。

掌握:

#1. 测试+链接数据库

   

    连接名:随意起名字就行,如果连接的是本地就输入本地连接就可以

    主机名或IP地址:填写localhost就是本地连接,也可以输入ip地址连接其他数据库

    端口:3306默认本地

    用户名:root默认的

    密码:我个人的数据库没密码,测试起来方便

#2. 新建库

    

#3. 新建表,新增字段+类型+约束

 创建student

#4. 设计表:外键
           
        我这个表的外键连接的是teacher表的tid

#5. 新建查询

           

#6. 备份库/表

 

         备份出的文件可以重新导入    

#注意:

批量加注释:ctrl+/键

批量去注释:ctrl+shift+/键


#提示本人的安装包跟上面下载的不一样,但是出入不大,操作什么的都一样

(上面下载的mysqlIDE运行之后点击注册,文件中有一个key文件,直接输入激活码就行)。

数据备份与恢复


pymysql

1.pymysql是python连接数据库的。

  • 首先安装pymysql

pip3 install python
  • 连接数据库
import pymysql
#链接
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
#host='连接地址',user='用户名',password='密码',database='数据库名称,charset ='utf8'

#游标
cursor=conn.cursor()

#执行sql语句
sql='select * from student' #注意%s需要加引号
print(sql)
res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
print(res)

cursor.close()
conn.close()


#运行结果
    select * from student
    4
#数据库实际数据:
   
mysql> select * from student;
+----+----------+------+-----------+---------+------------+
| id | name     | age  | phone     | address | teacher_id |
+----+----------+------+-----------+---------+------------+
|  1 | panbing  |   18 |  16547932 | 北京    |          1 |
|  2 | yancheng |   19 |    465465 | 湖南    |          2 |
|  3 | dachui   |   20 |  13587469 | 济南    |          3 |
|  4 | abo      |   21 | 147896523 | 山东    |          4 |
+----+----------+------+-----------+---------+------------+
4 rows in set (0.01 sec)
  • 对数据库的增
import pymysql

conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql='insert into student(id,name,age,phone,address,teacher_id) values("%s","%s","%s","%s","%s","%s")' #注意%s需要加引号
res=cursor.execute(sql,(5,'liuhu',18,154789632,'哈尔滨',4)) #执行sql语句,返回sql查询成功的记录数目
print(res)
conn.commit()
cursor.close()
conn.close()
执行结果
    1
数据库实际数据
mysql> select * from student;
+----+----------+------+-----------+----------+------------+
| id | name     | age  | phone     | address  | teacher_id |
+----+----------+------+-----------+----------+------------+
|  1 | panbing  |   18 |  16547932 | 北京     |          1 |
|  2 | yancheng |   19 |    465465 | 湖南     |          2 |
|  3 | dachui   |   20 |  13587469 | 济南     |          3 |
|  4 | abo      |   21 | 147896523 | 山东     |          4 |
|  5 | 'liuhu'  |   18 | 154789632 | '哈尔滨' |          4 |
+----+----------+------+-----------+----------+------------+
5 rows in set (0.00 sec)


#执行成功语句之后必须执行一句conn.commit()这样语句执行成功之后数据库里的数据才会显示。




#数据进行多条插入
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql='insert into student(name,age,phone,address,teacher_id) values("%s","%s","%s","%s","%s")' 

res=cursor.executemany(sql,[('liuhu',18,154789,'西藏',4),
                            ('huli',18,1589632,'哈尔滨',3),
                            ('cyhg',19,632,'内蒙',2)])
print(res)
conn.commit()
cursor.close()
conn.close()
#结果
    3
#数据库数据
  • 对数据库的删
import pymysql

conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql = 'truncate student'
res=cursor.execute(sql) #执行sql语句
conn.commit()
cursor.close()
conn.close()
执行之后数据库实际数据:
mysql> select * from student;
Empty set (0.00 sec)
  • 对数据库的改
更改数据库的表的名称

import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
conn.commit()
cursor.close()
conn.close()


执行后的结果

mysql> select * from student;
ERROR 1146 (42S02): Table 'day47.student' doesn't exist

mysql> select * from hello;
Empty set (0.00 sec)


  • 对数据库的查
import pymysql

conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql = 'select * from hello'
res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
print(res)
print(cursor.fetchone())
print(cursor.fetchone())
print(cursor.fetchmany(2))
print(cursor.fetchone())
conn.commit()
cursor.close()
conn.close()
输出结果:
6
(1, "'liuhu'", 18, 154789, "'西藏'", 4)
((2, "'huli'", 18, 1589632, "'哈尔滨'", 3), (3, "'cyhg'", 19, 632, "'内蒙'", 2))
(4, "'liuhu'", 18, 154789, "'西藏'", 4)
((5, "'huli'", 18, 1589632, "'哈尔滨'", 3),)
((6, "'cyhg'", 19, 632, "'内蒙'", 2),)


#fetchone()是显示一条数据,从头开始显示
#fetchmany()是更爱光标的位置括号内的值就是执行第几个光标



import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql = 'select * from hello'
res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
print(res)
print(cursor.fetchall())
conn.commit()
cursor.close()
conn.close()
输出结果:
6
((1, "'liuhu'", 18, 154789, "'西藏'", 4), (2, "'huli'", 18, 1589632, "'哈尔滨'", 3), (3, "'cyhg'", 19, 632, "'内蒙'", 2), (4, "'liuhu'", 18, 154789, "'西藏'", 4), (5, "'huli'", 18, 1589632, "'哈尔滨'", 3), (6, "'cyhg'", 19, 632, "'内蒙'", 2))

#fetchall()是显示表中所有的数据

2.execute()之sql注入

#示例代码:
import pymysql

username = input('用户名:》》').strip()
userpasswd = input('密码:》》').strip()
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql='select * from user where name="%s" and passswd="%s"' %(username,userpasswd) #注意%s需要加引号
print(sql)
res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
print(res)
conn.commit()
cursor.close()
conn.close()
if res:
    print('登陆成功')
else:
    print('登陆失败')
    
注意:符号--会注释掉它之后的sql,正确的语法:--后至少有一个任意字符

根本原理:就根据程序的字符串拼接name='%s',我们输入一个xxx' -- haha,用我们输入的xxx加'在程序中拼接成一个判断条件name='xxx' -- haha'

最后那一个空格,在一条sql语句中如果遇到select * from t1 where id > 3 -- and name='egon';则--之后的条件被注释掉了

#1、sql注入之:用户存在,绕过密码
egon' -- 任意字符

#2、sql注入之:用户不存在,绕过用户与密码
xxx' or 1=1 -- 任意字符
    示例图片(跳过密码):
        1.
2.
    解决方法:
    
# 原来是我们对sql进行字符串拼接
# sql="select * from userinfo where name='%s' and password='%s'" %(user,pwd)
# print(sql)
# res=cursor.execute(sql)

#改写为(execute帮我们做字符串拼接,我们无需且一定不能再为%s加引号了)
sql="select * from userinfo where name=%s and password=%s" #!!!注意%s需要去掉引号,因为pymysql会自动为我们加上
res=cursor.execute(sql,[user,pwd]) #pymysql模块自动帮我们解决sql注入的问题,只要我们按照pymysql的规矩来。



示例代码:
import pymysql

username = input('用户名:》》').strip()
userpasswd = input('密码:》》').strip()
conn=pymysql.connect(host='localhost',user='root',password='',database='day47',charset = 'utf8')
cursor=conn.cursor()
sql='select * from user where name=%s and passswd=%s'#注意%s需要加引号
print(sql)
res=cursor.execute(sql,[username,userpasswd]) #执行sql语句,返回sql查询成功的记录数目
print(res)
conn.commit()
cursor.close()
conn.close()
if res:
    print('登陆成功')
else:
    print('登陆失败')
    示例结果:
        
 

 


















posted @ 2017-09-18 19:55  你好丶  阅读(138)  评论(0编辑  收藏  举报