MySQL视图及如何导入导出

1.视图

MySQL 视图(View)是一种虚拟存在的表,同真实表一样,视图也由列和行构成,但视图并不实际存在于数据库中。行和列的数据来自于定义视图的查询中所使用的表,并且还是在使用视图时动态生成的,视图可以从原有的表上选取对用户有用的信息,那些对用户没用,或者用户没有权限了解的信息,都可以直接屏蔽掉,作用类似于筛选。这样做既使应用简单化,也保证了系统的安全

2.视图与数据表的区别

1.视图不是数据库中真实的表,而是一张虚拟表,其结构和数据是建立在对数据中真实表的查询基础上的

2.存储在数据库中的查询操作 SQL 语句定义了视图的内容,列数据和行数据来自于视图查询所引用的实际表,引用视图时动态生成这些数据

3.视图是数据的窗口,而表是内容。表是实际数据的存放单位,而视图只是以不同的显示方式展示数据,其数据来源还是实际表。

4.视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些 SQL 语句的集合。

5.视图的建立和删除只影响视图本身,不影响对应的基本表

3.语法

可以使用 CREATE VIEW 语句来创建视图。语法格式如下:

复制代码
CREATE VIEW <视图名> AS <SELECT语句>

4.导入与导出

导出表数据和表结构

复制代码
mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql(这个名字随便叫)

例如:

复制代码
/usr/local/mysql/bin mysqldump -uroot -pabc >abc.sql

只导出表结构

复制代码
mysqldump -u用户名 -p密码 -d 数据库名 > 数据库名.sql

例如:

复制代码
mysqldump -uroot -p -d abc > abc.sql
  • 导入

方法一:

复制代码
mysql> create database abc;         #建立空数据库
mysql> use abc;                     #选择数据库
mysql> set names utf8;              #设置数据库编码
mysql> source D:/home/abc/abc.sql;  #导入数据

方法二:

复制代码
mysql -u用户名 -p密码 数据库名 < 数据库名.sql

例如:

复制代码
mysql -uroot -p123456 abc < abc.sql

注意:在mysql.ini文件的[mysqld]配置下增加secure_file_priv=E:/test(可修改位置),在重启mysql服务。

  • 导出:

复制代码
  select * from 表名 into outflie 'E:/文件名.sql'
  • 导入

复制代码
  load data infile '/文件名.sql' into table 表名(列名1,...)
相关推荐
HUGu RGIN2 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
HackTwoHub3 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t3 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK3 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)4 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
S1998_1997111609•X5 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK6 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
BU摆烂会噶7 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t7 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper8 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程