下载包,导入包
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
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
sk =
socket.
socket()
ip_port = (
'127.0.0.1',
9998)
sk.
bind(ip_port)
sk.
listen(
5)
while True:
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()