免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2014 | 回复: 1
打印 上一主题 下一主题

关于MySQL导出view的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-05 17:19 |只看该作者 |倒序浏览
环境: win2000+MySQL5.0
用root在MySQL的数据库orders里创建了一张视图'details'

CREATE VIEW details (order_id, customer_id, employee_id, order_date, discount, paid,
quantity, product_name, price, company_name, reseller)
AS
SELECT o.order_id, o.customer_id, o.employee_id, o.order_date, o.discount, o.paid,
      od.quantity, p.product_name, p.price, c.company_name, c.reseller
FROM orders o INNER JOIN
      order_details od ON o.order_id = od.order_id INNER JOIN
      products p ON od.product_id = p.product_id INNER JOIN
      customers c ON o.customer_id = c.customer_id
WHERE (o.customer_id < 10)

然后是用mysqldump导出数据库。
mysqldump -u root -p 123456 orders > d:\\orders.sql
进入MySQL,删除数据库orders,将orders.sql导回。
发现视图details已经不能get到数据。


打开orders.sql,发现这一段:
-- Table structure for table `details`
--

DROP TABLE IF EXISTS `details`;
/*!50001 DROP VIEW IF EXISTS `details`*/;
/*!50001 DROP TABLE IF EXISTS `details`*/;
/*!50001 CREATE TABLE `details` (
  `order_id` int(10),
  `customer_id` tinyint(2),
  `employee_id` tinyint(2),
  `order_date` date,
  `discount` decimal(2,2),
  `paid` varchar(5),
  `quantity` tinyint(2),
  `product_name` varchar(40),
  `price` decimal(6,2),
  `company_name` varchar(50),
  `reseller` varchar(5)
) */;

--

也就是说没有给我还原回去我创建的那个view,只是创建了一个空的table.
请求各位帮帮忙,该怎样在MySQL里导出一个view,使得还原回去还是好好的。
谢谢了!

论坛徽章:
0
2 [报告]
发表于 2008-12-05 21:07 |只看该作者
VIEW在导出的时候是按照表的形式的,不必大惊小怪。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP