表内容有以下列:
id,name,age,phone,dept,enroll_date
//db1 数据库名 //emp表名 数据库表名和对应文件要关联上。
通过PYTHON脚本模拟实现以下SQL语句:
增删改查
sql>select
sql>select * from db1.emp
sql>select * from db1.emp limit 3 // 查前3条
sql>select * from db1.emp where id > 24
sql>select * from db1.emp where name like 李
sql>select * from db1.emp where id >10 and id < 14 or name like 李
sql>select * from db1.emp where not id > 3
sql>select name from db1.emp
sql>select name from db1.emp where
查询到的信息以列表的形式显示出来
sql>insert id 递增 以phone做唯一键,phone存在即提示
sql>insert into db1.emp values 'Tom,23,13212323276,运维,2017-05-16'
sql>insert successful
delete
sql>delete from db1.emp where id > 25
sql>delete successful
update update staff_table set dept=Market,phone=13566677787 where dept = 运维
sql>update db1.emp set name='sb' where id=24
sql>update db1.emp set name='alex' where name like sb
sql>update successful
sql>exit
脚本内容如下:
##################################################################
#!/usr/bin/env python
# _*_ coding:utf-8 -*-
import sys
test_db_file='db1/emp'
key_word = ['select', 'insert', 'delete', 'update', 'from', 'into', 'set', 'values', 'where', 'limit']
where_list=['>','<','like']
logic_list=['and','or','not']
# 判断有没有where
def check_where(db_ff,sql_ii):
#db_ff为行内容,sql_ii为SQL语句的列表
# 判断SQL中是否有where,并提取where后面的语句。
if 'where' in sql_ii:
sel_index = int(sql_ii.index('where')) + 1
where_info = sql_ii[sel_index:]
#print(where_info)
# 判断有没有逻辑条件。
k=0
for key_w in logic_list:
if key_w in where_info:
print(key_w)
k=1
if k==0:
print(where_info)
else:
return db_ff
def file_all():
# 提取所有行,返回一个列表OK。
db_f = []
with open(test_db_file, encoding='utf-8') as db_file:
db_f1 = db_file.readlines()
for f in db_f1:
f = f.strip().split(',')
db_f.append(f)
return db_f
def limit_row(sel_num):
# 提取limit限制的行数, sel_num为行数,OK
db_f=file_all()
limit_f=[]
# sql_num 要显示的行数
sel_num = int(sel_num)
# 判断显示的行数要小于等于表的总行数。
if len(db_f) >= sel_num:
for i in range(0, sel_num):
limit_f.append(db_f[i])
return limit_f
else:
print("Not have %s row in table! " % sel_num)
return limit_f
def get_column(column_name,db_ff):
# 提取某一列column_name为列名,db_ff为提取出来的行内容。OK
column_names = file_all()[0] ## 获取表的列名
# print(column_names)
if column_name in column_names:
column_nu = column_names.index(column_name)
for db_fff in db_ff:
print(db_fff[column_nu])
def db_select(select,*sql_i):
for sql_ii in sql_i:
pass
#print(sql_ii)
# 取匹配行的所有内容
if sql_ii[0] == '*':
db_ff=file_all()
#print(db_f)
# 判断SQL里是否有limit限制,如果有就获取限制的行数。
if 'limit' in sql_ii:
# 获取限制的行数
sel_index=int(sql_ii.index('limit'))+1
sel_num=sql_ii[sel_index]
#print(sel_num)
db_ff=limit_row(sel_num)
print(db_ff)
else:
print(db_ff)
check_where(db_ff, sql_ii)
# 取匹配行的某一列
else:
# 先判读是取所有行,还是取limit限制的行,然后从这些行中提取某一列
if 'limit' in sql_ii:
# 获取限制的行数
sel_index=int(sql_ii.index('limit'))+1
sel_num=sql_ii[sel_index]
db_ff=limit_row(sel_num)
else:
db_ff = file_all()
print(db_ff)
get_column(sql_ii[0], db_ff)
#pass
##########################################################
def db_delete():
pass
def db_insert():
pass
def db_update():
pass
if __name__ == "__main__":
#print(file_all())
#print (limit_row(file_all(), '2'))
#a=db_select()
#print(a)
while True:
sql_info=input("sql>")
sql_info=sql_info.strip().split()
print("sql_info:", sql_info)
if sql_info[0].lower() == 'quit' or sql_info[0].lower() == 'exit':
print('退出')
sys.exit(0)
elif sql_info[0].lower()=='select':
db_select('select',sql_info[1:])