python进阶10 MySQL补充 编码、别名、视图、数据库修改
python进阶10 MySQL补充 编码、别名、视图、数据库修改
一、编码问题
#MySQL级别编码
#修改位置: /etc/mysql/mysql.conf.d/mysqld.cnf
default-character-set = utf8 character-set-server =utf8
collation-server= utf8_general_ci #最佳实践
#1、无论mysql是否设置了对的编码都无所谓
#2、创建数据库的时候指定CHARSET utf8
#3、如果数据库的某张表需要别的编码,在创建表的时候指定 #python常用编码分为 utf8 gdk ASCII,其中utf8兼容ASCLL,gbk为纯中文 #创建库时指定库编码:
CREATE DATABASE mydb CHARACTER SET gbk;#创建数据库mydb的时候指定编码为gbk #创建数据表时指定的编码:
CREATE TABLE mytb( id INT ) CHARSET utf8;#创建数据表mytb是指定编码为utf8
二、别名
#作用有两个,一个用于展示,另一个用于子查询 #展示
#举个栗子:原来的表头是name,number,age,为了可以展示给中国人看名字,学号,年龄,可以如下操作
SELECT name AS 名字,number AS 学号,age AS 年龄 FROM students; #子查询
#举个栗子:如果一张表由19班和18班的人混合在一起,将19班和18班分开后出现了两张表,这个时候如果要查询这两张表,就需要用到别名 SELECT * FROM (SELECT * FROM students WHERE klass=19);#这种情况会报错,ERROR 1248 (42000): Every derived table must have its own alias(每张表必须要有他自己的别名) #正确展示
SELECT * FROM (SELECT * FROM students WHERE klass=19) AS tb; #给后面的部分一个别名 tb ,这样就可以实现自查询了
三、视图
#作用:
#如果说一个查询后的表使用频率比较高,可以用视图来封装这个查询,以便多次利用节省代码
#视图不是真的表,里面没有数据,只是封装了个查询而已
#查询视图的时候看上去像是查询一个表,其实只是间接地调用了那个被封装的查询 #创建一个视图
CREATE VIEW students_19 AS SELECT * FROM students WHERE klass=19; #封装了“19班”查询的视图 #修改一个视图
ALTER VIWE students AS SELECT * FROM students WHERE klass=18; #将students_19 这个视图的内容改为18班的内容
四、表结构修改
修改列
#背景
#通常情况下,应该一开始就尽量的设计好,因为数据库一旦设计完成,最好不要大改。但是,谁都不能保证,我的表永远够用,随时有可能需要改动。因此,我们还是要了解一下,修改表结构。
#注意:表结构修改,一般也不是开发区做。 #补充命令
DESC tb_name ;#表描述
SHOW KEYS FROM tb_name;#表中键
ALTER TABLE ...#主命令:修改表
#添加列
ADD COLUMN ... ALTER TABLE students ADD COLUMN gender BOOL;#将gender列添加到最后一列
#序位:FIRST (第一) AFTER (在...后) ALTER TABLE students ADD COLUMN gender BOOL NOT NULL DEFAULT TRUE FIRST ;#将gender列添加到第一列,加上非空并添加默认值TRUE ALTER TABLE students ADD COLUMN gender BOOL NOT NULL DEFAULT TRUE AFTER klass; #将gender列添加到klass后面,加上非空并添加默认值TRUE
#删除列
DROP COLUMN ALTER TABLE students DROP COLUMN gender;#删除gender列
#修改列
#仅修改列:
MODIFY COLUMN ... ALTER TABLE students MODIFY COLUMN gender BOOL NOT NULL DEFAULT TRUE AFTER age;#将gender列移动到age后面,并添加非空和默认值 #带重命名
ALTER TABLE students CHANGE COLUMN birth birthday DATETIME ;#将birth列改为birthday的一个DATETIME 类型列
修改键
#添加约束建
ADD PRIMARY KEY
ALTER TABLE students ADD PRIMARY KEY(number);#为number列添加之间约束(唯一键也是类似) ALTER TABLE students ADD UNIQUE KEY (aaaaaa);#为aaaaaa列添加唯一键约束 ALTER TABLE students ADD UNIQUE KEY (number);#在number为主键的前提下,这个操作会移除主键约束,但是会保留非空
#删除约束键
#删除主键
DROP PRIMARY KEY ALTER TABLE students DROP PRIMARY KEY ;#删除主键 ALTER TABLE students DROP KEY number;#删除唯一键number #显示创建信息的时候,会出现UNIQUE KEY 'numebr' ('numebr') UNIQUE KEY表列名,中间number是键名,后面的number是哪些列,无论是创建还是删除的时候,都是操作键名,而不是键
#注意:这里的number值的是键的名字而不是列名
#无功能键(索引)
#背景:如果说查找表的时候是按照某一列来查找的,那么这一列就可以添加索引 #添加索引
ADD KEY
ALTER TABLE students ADD KEY (name); #删除索引
DROP KEY
ALTER TABLE students DROP KEY (name); #注意,这里的索引指的是键的名字,而不是列名
python进阶10 MySQL补充 编码、别名、视图、数据库修改的更多相关文章
- python进阶08 MySQL基础补充
python进阶08 MySQL基础补充 本次课程都是基于三张表格的使用 一.子查询 #如何找到‘张三’的成绩 #思路:先找到张三的学号,在拿这个张三的学号到成绩表里面去匹配,得出成绩 #如何用一条查 ...
- python进阶07 MySQL
python进阶07 MySQL 一.MySQL基本结构 1.认识MySQL #MySQL不是数据库,它是数据库管理软件 #MySQL如何组织数据 #如何进入MySQL数据库 #其他注意事项 #以表格 ...
- python进阶09 MySQL高级查询
python进阶09 MySQL高级查询 一.筛选条件 # 比较运算符 # 等于:= 不等于:!= 或<> 大于:> 小于:< 大于等于>= 小于等于:<= #空: ...
- python(10)- 字符编码
一 什么是编码? 基本概念很简单.首先,我们从一段信息即消息说起,消息以人类可以理解.易懂的表示存在.我打算将这种表示称为“明文”(plain text).对于说英语的人,纸张上打印的或屏幕上显示的英 ...
- Python全栈开发之MySQL(三)视图,存储过程触发器,函数,事务,索引
一:视图 1:什么是视图? 视图是指存储在数据库中的查询的SQL语句,具有简单.安全.逻辑数据独立性的作用及视点集中简化操作定制数据安全性的优点.视图包含一系列带有名称的列和行数据.但是,视图并不在数 ...
- Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)
day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库: 简称:DataBase ---->DB 数据库即存放数据的仓库, ...
- MySQL进阶:约束,多表设计,多表查询,视图,数据库备份与还原
MySQL进阶 知识点梳理 一.约束 1. 外键约束 为什么要有外键约束 例如:一个user表,一个orderlist 如果现在想要直接删除id为1的张三,但是orderlist里还有用户id为1的订 ...
- Python自动化 【第十二篇】:Python进阶-MySQL和ORM
本节内容 数据库介绍 mysql 数据库安装使用 mysql管理 mysql 数据类型 常用mysql命令 创建数据库 外键 增删改查表 权限 事务 索引 python 操作mysql ORM sql ...
- Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁
Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...
随机推荐
- navicat for mysql 安装
直接上正题,用于记录 1.下载linux版本的navicat:http://www.navicat.com/download/navicat-for-mysql 2.解压 tar -vzxf navi ...
- 引用 qsort与sort的比较
引用 linpder 的 qsort与sort的比较 在C/C++标准库中提供了快速排序的函数qsort():在STL中也提供了sort()排序函数,那么这两个函数哪个快呢?之前与代码-> ...
- Java微信公众平台开发_05_微信网页授权
GitHub源码:https://github.com/shirayner/weixin_gz 一.本节要点 1.网页授权回调域名 登录微信公众平台后台, 开发 - 接口权限 - 网页服务 - 网页帐 ...
- overflow:hidden真的失效了吗?
项目中常常有同学遇到这样的问题,现象是给元素设置了overflow:hidden,但超出容器的部分并没有被隐藏,难道是设置的hidden失效了吗? 其实看似不合理的现象背后都会有其合理的解释. 我们知 ...
- Codeforces 762B USB vs. PS/2 贪心
Codeforces 762B 题目大意: 有a台只有USB接口的电脑,b台PS/2接口的电脑,c台两种接口都有的电脑.每台电脑只用装一个鼠标.给出n个鼠标及其费用,每个鼠标只能使用一遍.在最大化有鼠 ...
- cocos2dx 获取精灵的高亮效果
转自:http://blog.csdn.net/tyxkzzf/article/details/38703883 CCSprite* getHighlightSprite(CCSprite* norm ...
- 用WINHEX合并两个或多个BIN文件
以前,我给W25Q16下载内容的时候,每次都要分别传输GBK字符.英文字符和图片BIN文件,每次都要传输好几次. 后来,我发现,用WINHEX软件可以把这些BIN文件都合并到一个文件,只需要传输一次就 ...
- 三层架构与MVC比较:
三层架构与MVC比较: 1.两者不是同一概念 三层架构是一个分层式的软件体系架构设计,它可适用于任何一个项目. MVC是一个设计模式,它是根据项目的具体需求来决定是否适用于该项目. 那么架构跟设计模式 ...
- 'ascii' codec can't decode byte 0xe6 in position 0: ordinal not in range(128)
No valid host was found. There are not enough hosts available 'ascii' codec can't decode byte 0xe6 i ...
- [hdu4738]求桥模板
oj问题,待修改,存档. #include<stdio.h> #include<iostream> #include<cstdio> #include<sta ...