# 定义视图建议以v_开头
create view 试图名称 as select语句;
# 使用试图(视图的用途就是查询)
select * from v_stu_score;
# 删除试图
drop view 试图名称;
例:drop ciew v_stu_sco;
1.提高了重用性,就像一个函数
2.对数据库重构,却不影响程序的运行
3.提高了安全性能, 可以对不同的用户
4.让数据更加清晰
# 查看表的创建语句可以看到
- engine = innodb
-- 选择数据库
- use jing_dong;
-- 查看goods 表
- show create table goods;
# 开启事务命令
- 开启事务后执行修改命令,变更会维护到本地缓存中,而不维护到物理表中
- begin 或者 start transaction;
# 提交事务命令
- 将缓存中的数据变更维护到物理表中
- commit
# 回滚事务命令
- 放弃缓存中变更的数据
- rollback
索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。更通俗的说,数据库索引好不比是一本书前面的目录,能加快数据库的查询数据
目的:在于提高查询效率
# 查看索引
- show index from 表名
# 创建索引
- 如果指定字段是字符串,需要指定长度,建议长度与定义字段的长度一致
- 字段类型如果不是自妇产么可以不填写长度部分
- create index 索引名称 on 表名(字段名称(长度))
# 删除索引
- drop index 索引名称 on 表名;
# 授权权限
- 查看所有用户(所有用户及权限信息存储在mysql数据库的user表中)
- select host,user,authentication_string from user;
- 主要字段说明
- Host 表示允许访问的主机
- User表示用户名
- authentication_string白哦是密码,为加密后的值
- 创建账户、授权
- 需要使用实例级账户登录后操作,以root为例
- 常用权限主要包括:create、alter、drop、insert、update、delete、select
- 如果分配所有权限,可以使用all privileges
- grant 权限列表 on 数据库 to "用户名"@"访问主机" identified by "密码";
- 修改密码
- 使用password()函数惊醒密码加密
- update user set authentication_string=password("新密码") where user = "用户名";
- 例:update user set authentication_string=password("123") where user = "localhost";
- 注意修改完密码后需要刷新权限
- 刷新权限:flush pricileges
- 删除用户
# 语法1:使用root 登录
- drop user "用户名"@"主机";
- 例: drop user "laowang"@"%";
# 语法2: 使用root 登录,删除mysql数据库的user表中数据
- delete from user where user= "用户名";
- 例:delete from user where user = "laowang";
# 操作结束后需要刷新权限
- flush privileges
# 修改权限
- grant 权限名称 on 数据库 to 账户@主机 with grant option;
# 远程登录(危险慎用)
- 修改 /ect/mysql/mysql.conf.d/mysqld,cnf文件
- 然后重启mysql
- service mysql restart
- 连不上原因
- 网络不通
- 查看数据库是否配置了bind_address参数
- 查看数据库是否设置了skip_networking参数
- 端口指定是否正确
- 通过增加从服务器来提高数据库的性能,在主服务器上执行写入和更新,在从服务器上向外提供读功能,可以动态调整从服务器的数量,从而调整整个数据库的性能
- 提高数据安全,因为数据已复制到从服务器,从服务器可以终止复制进程,所以,可以在从服务器上备份不破坏主服务器响应数据
- 在主服务器上生成实时数据,而在从服务器上分析这些数据,从而提高主服务器的性能
1.在主服务器上,必须开启二进制日志机制和配置一个独立的ID
2.在每一个从服务器上,配置一个唯一的ID,创建一个用来专门复制主服务器数据的帐号
3.在开始复制进程前,在主服务器上记录二进制文件的位置信息
4.如果在开始复制之前,数据库中已经有数据,就必须先创建一个数据快照(可以使用mysqldump导出数据库,或者直接复制数据文件)
5.配置从服务器要连接的主服务器的IP地址和登录授权,二进制日志文件名和位置
1.备份主服务器原有数据到从服务器
# 在数服务器Ubuntu上备份,执行命令
mysqldump -uroot -pmysql
--all-databases
--lock-all-tables > ~/master_db.sql
# 说明
* - u:用户名
* - p:密码
* --all-databases: 导出所有数据库
* --lock-all-tables: 执行操作时锁定所有表,防止操作时有数据修改
* ~/master_db.sql: 导出的备份数据(sql文件)位置,可以自己指定
# 在从服务器Windows上进行数据还原
mysql -uroot -pmysql < master_db.sql
2.配置主服务器master(Ubuntu中的MySQL)
# 编辑设置mysqld的配置文件,设置log_bin和server-id
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
# 重启mysql服务器
sudo service mysql restart
# 登入主服务器Ubuntu中的mysql,创建用于从服务器同步数据使用的帐号
mysql - uroot -pmysql
GRANT REPLICAION SLAVE NO *.* TO "slave"@"%" identified by "slave";
FLUSH PRIVLEGES;
# 获取主服务器的二进制日志信息
SHOW MASTER STATUS;
3.配置从服务器slave(Windows中的MySQL)
# 找到Windows 中的MySQL的配置文件
# 编辑my.ini文件,将server-id修改为2,并保存退出
# 打开windows服务管理器
# 在打开的服务管理中找到MySQL57,并重启该服务
change master to master_host= "10.211.55.5", master_user= "slave", master_password= "slave", master_log_file = "mysql-bin.000006", master_log_pos=590;
* mastr_host: 主服务器Ubuntu的ip地址
* master_log_file:前面查询到的主服务器日志文件名
* master_log_pos: 前面查询到的主服务器日志文件位置