• ADADADADAD

    MySQL第三天[ mysql数据库 ]

    mysql数据库 时间:2024-12-25 09:55:30

    作者:文/会员上传

    简介:

    MySQL第二天 关键词:分组聚合自关联物理上一张表,逻辑上是两张表create table areas(id int primary key,atitle varchar(20),pid int,foreign key(pid) references areas(id)

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    MySQL第二天

    关键词:分组聚合

    自关联

    物理上一张表,逻辑上是两张表

    create table areas(id int primary key,atitle varchar(20),pid int,foreign key(pid) references areas(id));

    导入sql文件

    source areas.sql;

    示例图

    示例语句

    select sheng.id as sid,sheng.title as stile,shi.id as shiid,shi.title as shititle from areas as shenginner join areas as shi on sheng.id=shi.pidwhere sheng.pid is null and sheng.title='山西省'limit 0,100;
    视图

    create view stuscore as + 查询语句

    事务

    四个特性(ACID)

    原子性(Atomicity):事务不可分割一致性(Consistency):事务间执行顺序不影响结果隔离性(Isolation):不受干扰持久性(Durability):对数据库的更改不丢失

    引擎类型:engine=innodb/bdb 支持事务,默认innodb
    查看表创建的语句: show create table students;
    修改表类型 : alter table students engine=innodb;

    事务语句

    begin; //开启commit; //提交rollback; // 回滚操作
    索引

    查看索引

    show index from 表名;

    创建索引

    create index indexName on areas(title(20));

    删除索引

    drop index [indexName] on 表名;

    执行时间

    开启执行时间监测:set profiling=1; 执行语句显示监测结果 : show profiles;Python的数据库操作

    每一个python会话都是一次事务

    常用类

    Connec类

    connection = connect(host,port,db,user,passwd,charset)

    connection对象的方法

    close() 关闭连接commit() 事务提交,所以需要提交才会生效rollback() 事务回滚,放弃之前的操作cursor() 返回Cursor对象,用于执行sql语句并获得结果

    Cursor

    执行SQL语句

    cursor1=connection.cursor() // 调用cursor方法 返回一个cursor对象

    cursor对象的常用方法

    execute(operation ,[ parameters ]) //执行语句,返回受影响的行数fetchone() //获取查询结果集的第一个行数据,返回一个元组fetchall()//获取查询结果集的所有行,一行构成一个元组,返回一个大元组
    增删改查
    import MySQLdbtry:connection=MySQLdb.connect(host='localhost',port=3306,db='python3',user='root',passwd='***',charset='utf8')cursor1=connection.cursor()sql='SQL语句增删查改'count=cs1.execute(sql)connection.commit()cursor1.close()connection.close()except Exception,e:print (e.message)
    参数化

    防止SQL注入

    from MySQLdb import *try:name = raw_input('请输入一个名字')connection = connect(host='localhost',port=3306,db='python3',user='root',passwd='***',charset='utf8')#sql = 'insert into students(name) values("小乖巧")'#sql = 'update students set name='乖巧' where id=3'#sql = 'delete from students where id = 3'sql = 'insert into students(name) values(%s)'cursor1.execute(sql,[name])connection.commit()cursor1.close()connection.close()except Exception,e:print (e.message)
    封装
    class MYSQL:def __init__(self,host,port=3306,db,user,passwd,charset='uft8'):self.host = hostself.port = portself.db = dbself.user = userself.passwd = passwdself.charset = charsetdef open(self):self.connection = connect(host=self.host,port=self.port,db=self.db,user=self.user,passwd=self.passwd,charset=self.charset)self.cursor = self.connection.cursor()def close(self):self.cursor.close()self.connection.close()def curd(self):try:self.open()self.cursor(sql,param)self.commit()self.close()except Exception,e:print(e.message)def all(self,sql,param=[]):try:self.open()self.cursor(sql,param)result = self.cursor.fetchall()self.commit()self.close()return resultexcept Exception,e:print(e.message)

    5/13/2018 9:57:42 PM

    MySQL第三天.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载