首页 SQL教程正文

【教程】Navicat/Pytcharm连接MySQL

從出茳湖 SQL教程 2019-08-22 71 0

Navicat_Pytcharm连接MySQL.png

Navicat/Pytcharm连接MySQL    >>>思维导图>>>博客园

Navicat连接MySQL

  • 测试+链接数据库

  • 新建库

  • 新建表,新增字段+类型+约束

  • 设计表:外键

  • 新建查询

  • 建立表模型

  • 批量加注释:ctrl+?键

  • 批量去注释:ctrl+shift+?键

Pytcharm连接MySQL

  • 安装pymysql模块

  • 代码连接

  • import pymysql
    # 链接
    conn=pymysql.connect(
      host='localhost',
      user='root',
      password='123',
      database='dbname',
      charset='utf8')  # 编码千万不要加- 如果写成了utf-8会直接报错
      autocommit = True  # 这个参数配置完成后  增删改操作都不需要在手动加conn.commit了
    # 游标
    cursor=conn.cursor()  # 执行完毕返回的结果集默认以元组显示
    cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)  
    # 产生一个游标对象  以字典的形式返回查询出来的数据 键是表的字段  值是表的字段对应的信息
  • pymysql操作数据库

  • user = input(">>>:").strip()
    pwd = input(">>>:").strip()
    sql='select * from userinfo where name="%s" and password="%s"' %(user,pwd)  # 注意%s需要加引号
    rows=cursor.execute(sql)  # 执行sql语句,返回sql查询成功的记录数目
    # 获取真实数据cursor.fetchone(),cursor.fetchall(),cursor.fetchmany(),类似管道取值,获取一条,所有,多条
    print(cursor.fetchone())  # 只获取一条数据
    print(cursor.fetchall())  # 获取所有的数据  返回的结果是一个列表
    cursor.scroll(1,'relative')  # 相对移动 relative相对于当前位置 往后移动几位
    cursor.scroll(3,'absolute')  # 绝对移动 absolute相对于起始位置 往后移动几位
    cursor.close()
    conn.close()
  • sql注入问题

  • # 不要手动去拼接查询的sql语句
    username = input(">>>:").strip()
    password = input(">>>:").strip()
    sql = "select * from user where username='%s' and password='%s'"%(username,password)
    # 用户名正确
    username >>>: jason' -- jjsakfjjdkjjkjs
    # 用户名密码都不对的情况
    username >>>: xxx' or 1=1 --asdjkdklqwjdjkjasdljad
    password >>>: ''
    """
    sql注入 就是利用注释等具有特殊意义的符号 来完成一些骚操作
    后续写sql语句  不要手动拼接关键性的数据
    而是让excute帮你去做拼接
    """
  • 增删改

  • # 增
    sql = "insert into user(username,password) values(%s,%s)"
    rows = cursor.excute(sql,('jason','123'))
    # 修改
    sql = "update user set username='jasonDSB' where id=1"
    rows = cursor.excute(sql)
    """
    增和改单单执行excute并不会真正影响到数据,需要再执行conn.commit()才可以完成真正的增改
    """
    # 一次插入多行记录
    res = cursor,excutemany(sql,[(),(),()])

本文标题:【教程】Navicat/Pytcharm连接MySQL
本文链接:https://zhong-er.com/post/70.html
作者授权:除特别说明外,本文由 從出茳湖 原创编译并授权 中二青年 刊载发布。
版权声明:本文使用「署名-非商业性使用-相同方式共享 4.0 国际」创作共享协议,转载或使用请遵守署名协议。

评论

本站会员尊享VIP特权,现在就加入我们吧!登录注册
登录
用户名
密码
注册
用户名
密码
确认密码
邮箱
获取邀请码
邀请码
验证码
找回密码
用户名
邮箱
※ 重置链接将发送到邮箱