python中的mysql数据库管理和socket

下载包,导入包
yum install mariadb-server.x86_64 -y
yum install gcc -y
yum search mysql-python
yum install MySQL-python.x86_64 -y
pip install MySQL-python

设置超户密码

mysql_secure_installation 
systemctl start mariadb.service 
mysql -uroot -p
网页版数据库
cd /var/www/html/
ls
tar jxf phpMyAdmin-3.4.0-all-languages.tar.bz2
ls
mv phpMyAdmin-3.4.0-all-languages mysqladmin
ls
cd mysqladmin/
ls
cp config.sample.inc.php config.inc.php 
yum install httpd php -y
yum search php
yum install php-mysql.x86_64 -y
systemctl start httpd
systemctl stop firewalld
执行数据查询
import MySQLdb
#打开门
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
#伸出手
#cur = conn.cursor() #创建了一个'手'
cur = conn.cursor(cursorclass = MySQLdb.cursors.DictCursor)
#拿东西
#这个操作影响了多少行数(有多少行被操作了)
recont = cur.execute('select * from userInfo')
#接收全部的返回结果行
data = cur.fetchall()
#把手伸回来
cur.close()
#把门关上
conn.close()
print recont
print data

这里写图片描述

执行数据增加
import MySQLdb
#打开门
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
#伸出手
cur = conn.cursor()
#操作数据
sql = 'insert into usermessage(id,name,address)values(%s,%s,%s)'
params = ('2','lxy','cn')
recount = cur.execute(sql,params)
#提交请求
conn.commit()
#把手伸回来
cur.close()
#把门关上
conn.close()
print recount

这里写图片描述

执行数据更改
import MySQLdb
#打开门
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
#伸出手
cur = conn.cursor()
#操作数据
sql = 'update usermessage set name = %s where id = %s'
params = ('lala','1',)
recount = cur.execute(sql,params)
#提交请求
conn.commit()
#把手伸回来
cur.close()
#把门关上
conn.close()
print recount

这里写图片描述

执行数据删除
import MySQLdb
#打开门
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
#伸出手
cur = conn.cursor()
#操作数据
sql = 'delete from usermessage where id = %s'
#它是一个元组,如果不加逗号,会被当作int型
params = (1,)
recount = cur.execute(sql,params)
#提交请求
conn.commit()
#把手伸回来
cur.close()
#把门关上
conn.close()
print recount
##你会发现id为1的被删除了

这里写图片描述

插入多条数据
import MySQLdb
#打开门
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
#伸出手
hand = conn.cursor()
#操作数据
li = [
     ('5','ford','123'),
    ('6','harry','321')]
my = 'insert into usermessage(id,name,address)values(%s,%s,%s)'
recount = hand.executemany(my,li)
#提交请求
conn.commit()
#把手伸回来
hand.close()
#把门关上
conn.close()
print recount

这里写图片描述

提交数据
import MySQLdb
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='1234',db='python')
cur = conn.cursor()

sql = 'update money set count = %s where id = 1'
params = ('0',)
recount = cur.execute(sql,params)

sql = 'update money set count = %s where id = 2'
param = ('100',)
recount = cur.execute(sql,param)
conn.commit()

没有提交之前
这里写图片描述
提交之后
这里写图片描述

什么是socket
网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket
所谓socket通常也称作“套接字”,用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过“套接字”向网络发出请求或应答网络请求
socket起源于Uinx,而Unix/Linux基本哲学之一就是“一切皆文件”,都可以用“打开open-->读写write/read-->关闭close”模式来操作,socket就是该模式的一个实现,socket即是一种特殊的文件,一些socket函数就是对其进行的操作(读/写 IO,打开,关闭)
Socket的英文原义是“孔”或“插座”。作为BSD UNIX的进程通信机制,取后一种意思。通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信。在Internet上的主机一般运行了多个服务软件,同时提供几种服务。每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务。Socket正如其英文原义那样,像一个多孔插座。一台主机犹如布满各种插座的房间,每个插座有一个编号,有的插座提供220伏交流电,有的提供110伏交流电,有的则提供有线电视节目。 客户软件将插头插到不同编号的插座,就可以得到不同的服务

例如:中国移动客服
对于移动来说:一直监听一个号码10086,当有电话进来后,就分配一个客服和客户去沟通并处理请求
对于用户:需要知道10086这个号码,并需要打电话

建立一个客户端.py文件

import socket
#创建一个socket对象
client = socket.socket()

#创建连接
ip_port = ('127.0.0.1',9998)
client.connect(ip_port)
while True:
    #获取数据
    data = client.recv(1024)
    print data
    #发送数据
    inp = raw_input('client:')
    client.send(inp)
    if inp == 'exit':
        break

建立一个服务端.py文件
然后再编辑器里执行服务端文件,再执行客户端文件,当两者端口和ip一致时就会产生交互

import socket
#1.创建socket对象
sk = socket.socket()
#2.绑定端口和ip
ip_port = ('127.0.0.1',9998)
sk.bind(ip_port)
#3.最大连接数
sk.listen(5)
while True:
    #获取客户端的ip和端口号
    conn,address = sk.accept()
    conn.send('hello')
    flag = True
    while True:
        data = conn.recv(1024)
        print data
        if data == 'exit':
            flag = False
        conn.send('sb')
    conn.close()

这里写图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值