温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL数据库的操作案例

发布时间:2020-10-24 14:02:16 来源:亿速云 阅读:172 作者:小新 栏目:编程语言

小编给大家分享一下MySQL数据库的操作案例,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

一、链接数据库

conn = pymysql.connect(host='127.0.0.1', port=3306, user='school_spt', passwd='123456', db='school_info')   #返回个链接对象

二、创建游标

cursor = conn.cursor()

三、sql拼接命令

1.字符串拼接(不推荐使用该方式,容易被sql注入)

user='root'
pwd='123456'
sql='select * from userinfo where password=%s and username=%s'%(pwd,user)

2.pymysql命令自带拼接

executsql命令, args)    #args可以是列表,元组或者字典
 
列表:
 
user='root'
pwd='123456'
sql='select * from userinfo where password=%s and username=%s'
cursor.execute(sql,[pwd,user])
元组
user='root'
pwd='123456'
sql='select * from userinfo where password=%s and username=%s'
cursor.execute(sql,(pwd,user))
 
字典
sql='select * from userinfo where password=%(password)s and username=%(username)s'
cursor.execute(sql,({'password':pwd,'username':user}))

四、查

sql='select * from userinfo'
res=cursor.execute(sql)   #返回受影响的行数
#获取返回的数据
cursor.fetchone()      #获取返回的第一行内容
cursor.fetchmany(n)    #获取返回的前n行内容
cursor.fetchall()          #获取返回的全部内容
 
#返回的数据默认是元组形式,如果要以字典形式显示
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

五、改(改,删,增)

1.增

 sql=‘insert into userinfo(username,password) values(%s,%s)’
    cursor.execute(sql,('root','123'));   #单条插入
    也可以使用批量插入数据
    cursor.executemany(sql,[('root','123'),('root1','1234'),('root2','123')]);

2.改,删没有批量执行命令,批量一般都使用单条执行

3.增,删,改操作后,都需要使用 conn.commit()来确认提交数据

六、execute会返回受影响的行数。一般不适用

七、scroll 在fetch数据时按照顺序进行(类似生成器),可以使用cursor.scroll(num,mode)来移动游标位置,如:

cursor.scroll(1,mode='relative')  # 相对当前位置移动
cursor.scroll(2,mode='absolute') # 相对绝对位置移动

八、获取最后的自增id值(lastrowid)

id=cursor.lastrowid

九、关闭游标和链接

cursor.close()  #先关闭游标
conn.close()    #再关闭连接

看完了这篇文章,相信你对MySQL数据库的操作案例有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI