关于mysql的安装可以参考之前Mysql的安装与配置
MySQL为主流的关系型数据库,还包括Oracle,SQL Server,Access…与之对应的为非关系型数据库,如NoSQL, cassandra,redis,hbase…详细了解可以参考百度百科第一条,非常详细
操作过程以登录验证为例
- 创建变量,获取键盘信息
user = input("请输入用户名:")
pwd = input("请输入密码:")
- 导入 pymysql 并创建连接
import pymysql
conn = pymysql.connect(
host='localhost', # localhost为主机,远程操作时为目标IP地址
port=3306, # 数据库默认端口号
user='root', # 数据库账号
password='123456', # 数据库密码
db='topic', # 数据库名
charset='utf8' # 编码格式
)
- 获得游标对象
cursor = conn.cursor()
# 把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理
- 编写登录验证时应避免SQL注入,不应使用如下数据获取方式
sql = 'select * from login where user="%s" and pwd="%s"' % (user, pwd)
# 这种方式存在安全漏洞,当使用 -- 注释和 or 判断时,极易跳过密码验证
- 防SQL注入方式
sql = 'select * from login where user=%s and pwd=%s'
# 获得键入的用户名和密码
rows = cursor.execute(sql,(user, pwd))
# 将执行语句传入游标,执行sql语句
cursor.close()
# 关闭游标
- 关闭连接
conn.close()
- 对键入数据进行判断
if rows: # 自带布尔属性
print("登录成功!")
else:
print("用户名或密码错误!")