数据库问题求助

数据库问题求助,第1张

系和学生 为 一 对 多关系;

学生和课程 为 多 对 多关系;

E-R图现在没法画,因为我没有软件,5555

(1)求供应红色零件的供应商名字;

select ssname from s ,p ,sp where

ssno = spsno and ppno = sppno

and pcolor = '红色';

(2)求北京供应商的号码、名字和状况(Status);

select sno,sname,status from s where scity = '北京'

(3)求零件P2的总供应量 (SP表的qty字段是数量吗)

select count(spqty) from p,sp where ppname = 'P2' and ppno = sppno

(4) 把零件P2的重量加5,颜色改为**

update p set Weight = Weight+5 ,color ='**' where ppname = 'P2'

1、用phpMyAdmin打开要修改前缀的数据库>

Select CONCAT( 'ALTER TABLE ', table_name, ' RENAME TO ',

replace(table_name,'phpcms_','sdck_'),';')

from information_schematables

where TABLE_SCHEMA = '>

2、在执行SQL语句生成的页面上点击“导出”,选择“自定义”->“直接显示为文本”,CSV格式,清空“内容分隔符”为空。

3、执行导出功能后,到达结果窗口如下,复制文本框中的内容。

4、进入数据库“>

这个要分情况,作为IT老狗混迹过的企业不在少数,每个企业情况不一样,数据库管理难度也不一样。有的企业用的还是传统的数据库管理系统,非常的繁琐复杂,关键灵活性、稳定性和安全性也不行,即使天天加班都不一定能做好工作。但有的企业,利用先进数据库管理工具的帮助,数据库管理可以实现一键式 *** 作,非常方便快捷。

在这里跟大家推荐个非常好用的数据库管理工具,就是Nutanix最近推出了数据库管理相关的组合产品(NDB)。NDB 面向 PostgreSQL®、MySQL®、Microsoft® SQL 服务器、Oracle® 数据库等数据库引擎,简化了在混合多云环境下的数据库管理,具有非常强大的自动化功能,支持数据库实例的配置、扩展、修补、保护和克隆,还可以帮助客户在本地和公有云上为开发人员提供数据库即服务( DBaaS )和易用的自助式数据库体验,是企业进行数据库管理非常有力的工具,大家可以试试∞

1、自己在windows和linux上安装了mysql,自学linux的基础知识,学习mysql的最基础的知识,即怎么写sql,存储过程,表的设计等,从0到熟悉大概花了3个月,推荐《mysql入门很简单》。

2、系统地较为深入地学习mysql的sql优化,备份和恢复,参数优化,架构优化,硬件层面的优化,高可用方案,复制技术等等,这段时间你不一定能实际接触到这些,就像我当初那样,肯定没什么公司招一个小白。

我选择自己看书,推荐《高性能mysql》,里面所有的章节都需要看一遍,以现在的水平肯定看不懂,但需要知道大概怎么回事,为后续的找mysql初级dba的工作打一个铺垫,这个过程大概也需要3个月。

3、纸上得来终觉浅,完成以上两步,我开始准备找一份mysql相关的工作,而不是天天用着excel表格做着selectfromtable_sb这样的工作。

当然我这么猥琐的人肯定不会裸辞,该画的电路板也一样画,业余时间开始投初级mysqldba的工作,并且不间断地学习,网上各种找mysql面试的相关题目(实际上我当时完全没有任何实战经验),陆续收到一些面试,凭借之前自学的mysql知识,开始胡乱吹牛逼,先混进去再说。

你不做mysql实际相关的工作,永远也不知道自己之前认知的db知识有多幼稚。

友情提示一点,一般公司都没有专职dba的,所以面试的时候一定要自信,其实你学了这么多,虽然毫无实战经验,理论知识很大概率比面试你的人牛逼,所以各种吹,我就这样真正进入初级dba的圈子(由于这时对linux还处于cdls的水平,所以之前也根本没做过运维),这个边工作边找工作的过程又持续了2个月。

4、真正进入互联网,接触生产环境后,这是我进步最大的时候。

第一步需要将之前所学真正地应用起来,并且应用的过程中,再回头看之前的书籍,这时候需要真正去理解,而不是似是而非,一知半解。

这时再推荐《高性能mysql第三版》,全本再看一遍,这时需要全部看懂,另外还有《mysql技术内幕:innodb存储引擎》等等。

总之这段时间就需要开始关注mysql一些细节了,比如db故障处理,高可用,负载均衡等等的具体实现了。

另外,linux的知识同步也要深入去学习,至少会写shell脚本,常见的linux知识等,我在这花了1年多;

5、dba的工作一般是非常轻闲的,毕竟不是大公司,技术能力有限,该学的也学得差不多了,接触不到海量数据,高并发等比较锻炼人的场合,于是我又准备跳了。

于是来了公有云,现在每天运维万多个db实例,平均每天处理5个紧急db故障,几乎mysql会遇到的问题,感觉都遇到了,能感觉到技术实力和经验也在每天都在积累,在进步。

但是感觉还是欠缺了很多,下一步就看你选择了,是再去研究源代码,底层原理的东西多点,还是数据库运维和应用多一点,就比如业界姜承尧,何登成与叶金荣的区别。

由于我的历史原因,对c等几乎不懂,平时也用不到,所以看代码等事实际太累,于是我再去学mongodb,接了公司mongodb运维的活,算是在广度上的一个扩展,万一哪天mysql不行了呢

6、总之,对于db小白来说,最重要的一点就是,学习的过程不能断。

PS上面的方法比较野路子,适合没什么基础的童鞋,如果本来就是DBA,比如从oracle转到mysql,那么建议直接看mysql官方文档,而官方文档是db达到一定水平后必看,出问题时必查的权威文档。

网络信号不稳定、系统维护升级、数据库异常、客户填写的信息不正确。经天天宝官方客服回馈信息,查询客户签约性阿比通常是由四个原因导致的:

1、网络信号不稳定:由于天天宝是基于网络接口的查询系统,使用前需要确保网络连接稳定,否则就可能查询失败。

2、系统维护升级:天天宝可能出现系统维护升级的情况,导致客户无法查询签约信息。此时,建议稍后再次尝试查询。

3、数据库异常:可能是由于数据库出现异常导致客户查询签约信息失败。此时,客户可以向天天宝客服反馈,以便尽快解决问题。

4、客户填写的信息不正确:如果客户填写的信息不正确,则可能会导致查询失败。在查询签约信息之前,客户需要确保输入的个人信息准确有效。

如果你想查看乐透型**的数据库,可以通过以下几种方法:

1 访问体育**官网或福利**官网,官网上会提供最新的**开奖信息、历史开奖数据等。

2 搜索**资讯网站或**开奖查询网站,这些网站通常会提供**历史开奖数据、中奖号码统计、走势图等相关信息。常用的**资讯网站有**控、大乐透等。

3 下载**软件,如中**、天天**等,这些软件提供了最新的**开奖信息和历史开奖数据,还能实时更新和展示中奖号码的走势图和统计数据。

无论是哪种方式,都可以让你轻松地查看到乐透型**的开奖数据和走势信息。同时,对于购彩者来说,掌握历史开奖数据和中奖号码的走势有助于制定更科学的购彩策略。

视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。

对其中所引用的基础表来说,视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。通过视图进行查询没有任何限制,通过它们进行数据修改时的限制也很少。

视图是存储在数据库中的查询的SQL 语句,它主要出于两种原因:安全原因, 视图可以隐藏一些数据,如:社会保险基金表,可以用视图只显示姓名,地址,而不显示社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。这个视图就像一个“窗口”,从中只能看到你想看的数据列。这意味着你可以在这个视图上使用SELECT ,而你看到的将是你在视图定义里给出的那些数据列:

既然视图的定义是基于基本表的,哪为什么还要定义视图呢?这是因为合理地使用视图能够带来许多好处:

1、 视图能简化用户 *** 作

视图机制使用户可以将注意力集中在所关心地数据上。如果这些数据不是直接来自基本表,则可以通过定义视图,使数据库看起来结构简单、清晰,并且可以简化用户的的数据查询 *** 作。例如,那些定义了若干张表连接的视图,就将表与表之间的连接 *** 作对用户隐藏起来了。换句话说,用户所作的只是对一个虚表的简单查询,而这个虚表是怎样得来的,用户无需了解。

2、 视图使用户能以多种角度看待同一数据

视图机制能使不同的用户以不同的方式看待同一数据,当许多不同种类的用户共享同一个数据库时,这种灵活性是非常必要的。

3、 视图对重构数据库提供了一定程度的逻辑独立性

数据的物理独立性是指用户的应用程序不依赖于数据库的物理结构。数据的逻辑独立性是指当数据库重构造时,如增加新的关系或对原有的关系增加新的字段,用户的应用程序不会受影响。层次数据库和网状数据库一般能较好地支持数据的物理独立性,而对于逻辑独立性则不能完全的支持。

在关许数据库中,数据库的重构造往往是不可避免的。重构数据库最常见的是将一个基本表“垂直”地分成多个基本表。例如:将学生关系Student(Sno,Sname,Ssex,Sage,Sdept),

分为SX(Sno,Sname,Sage)和SY(Sno,Ssex,Sdept)两个关系。这时原表Student为SX表和SY表自然连接的结果。如果建立一个视图Student:

[sql]  view plain  copy

CREATE VIEW Student(Sno,Sname,Ssex,Sage,Sdept)AS SELECT SXSno,SXSname,SYSsex,SXSage,SYSdept FROM SX,SY WHERE SXSno=SYSno;

这样尽管数据库的逻辑结构改变了(变为SX和SY两个表了),但应用程序不必修改,因为新建立的视图定义为用户原来的关系,使用户的外模式保持不变,用户的应用程序通过视图仍然能够查找数据。

当然,视图只能在一定程度上提供数据的逻辑独立,比如由于视图的更新是有条件的,因此应用程序中修改数据的语句可能仍会因为基本表构造的改变而改变。

4、视图能够对机密数据提供安全保护

有了视图机制,就可以在设计数据库应用系统时,对不同的用户定义不同的视图,使机密数据不出现在不应该看到这些数据的用户视图上。这样视图机制就自动提供了对机密数据的安全保护功能。例如,Student表涉及全校15个院系学生数据,可以在其上定义15个视图,每个视图只包含一个院系的学生数据,并只允许每个院系的主任查询和修改本原系学生视图。

5、适当的利用视图可以更清晰地表达查询

例如经常需要执行这样的查询“对每个学生找出他获得最高成绩的课程号”。可以先定义一个视图,求出每个同学获得的最高成绩:

[sql]  view plain  copy

CREATE VIEW VMGRADE

AS

SELECT Sno,MAX(Grade) Mgrade

FROM SC

GROUP BY Sno

然后用如下的查询语句完成查询:

[sql]  view plain  copy

SELECT SCSno,Cno FROM SC,VMGRADE WHERE SCSno = VMGRADESno AND SCGrade = VMGRADEMgrade;

二、数据准备

1、员工表

[sql]  view plain  copy

CREATE TABLE t_employee(

ID INT  PRIMARY KEY  AUTO_INCREMENT,

NAME CHAR(30) NOT NULL,

SEX  CHAR(2) NOT NULL,

AGE INT NOT NULL,

DEPARTMENT CHAR(10) NOT NULL,

SALARY  INT NOT NULL,

HOME CHAR(30),

MARRY CHAR(2) NOT NULL DEFAULT  '否',

HOBBY CHAR(30)

);

插入数据:

[sql]  view plain  copy

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'小红','女',20,'人事部','4000','广东','否','网球');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'明日','女',21,'人事部','9000','北京','否','网球');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'天天','男',22,'研发部','8000','上海','否','音乐');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'大大','女',23,'研发部','9000','重庆','否','无');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'王下','女',24,'研发部','9000','四川','是','足球');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'无名','男',25,'销售部','6000','福建','否','游戏');

INSERT INTO learningt_employee(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'不知道','女',26,'销售部','5000','山西','否','篮球');

插入的结果:

然后再定义一张员工信息表:

[sql]  view plain  copy

create TABLE t_employee_detail(

ID INT PRIMARY KEY,

POS CHAR(10) NOT NULL,

EXPERENCE CHAR(10) NOT NULL,

CONSTRAINT `FK_ID` FOREIGN KEY(ID) REFERENCES t_employee(ID)

)

插入如下:

[sql]  view plain  copy

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(1,'人事管理','工作二年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(2,'人事招聘','工作二年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(3,'初级工程师','工作一年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(4,'中级工程师','工作二年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(5,'高级工程师','工作三年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(6,'销售代表','工作二年');

INSERT INTO t_employee_detail(ID,POS,EXPERENCE) VALUES(7,'销售员','工作一年');

内容:

三、使用案例

1 语法

CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}] VIEW [db_name]view_name [(column_list)] AS select_statement [WITH [CASCADED | LOCAL] CHECK OPTION]

通过该语句可以创建视图,若给定了[OR REPLACE],则表示当已具有同名的视图时,将覆盖原视图。select_statement是一个查询语句,这个查询语句可从表或其它的视图中查 询。视图属于数据库,因此需要指定数据库的名称,若未指定时,表示在当前的数据库创建新视图。

表和数据库共享数据库中相同的名称空间,因此,数据库不能包含相同名称的表和视图,并且,视图的列名也不能重复。

在创建视图前应先看看是否有权限:

[sql]  view plain  copy

SELECT SELECT_priv,create_view_priv from mysqluser WHERE user='root'

Y表示有创建的权限

2、单表上创建视图

在员工表是创建视图

[sql]  view plain  copy

CREATE VIEW V_VIEW1(ID, NAME, SEX, AGE,DEPARTMENT) AS SELECT ID, NAME, SEX, AGE,DEPARTMENT FROM learningt_employee;

然后是显示内容:

[sql]  view plain  copy

SELECT  FROM V_VIEW1

3、多表上创建视图

[sql]  view plain  copy

CREATE VIEW V_VIEW2(ID, NAME, SEX, AGE,DEPARTMENT,POS,EXPERENCE) AS SELECT aID, aNAME, aSEX, aAGE,aDEPARTMENT,bPOS,bEXPERENCE FROM learningt_employee a,learningt_employee_detail b WHERE aID=bID;

显示结果 

[sql]  view plain  copy

SELECT  FROM V_VIEW2

4、查看视图

(1)DESCRIBE 命令

[sql]  view plain  copy

DESCRIBE V_VIEW2

(2)SHOW TABLE STATUS 

[sql]  view plain  copy

show TABLE status LIKE 'V_VIEW2'

(3)SHOW CREATE view命令

[sql]  view plain  copy

show CREATE view V_VIEW2

5、修改视图

(1)CREATE OR REPLACE命令

[sql]  view plain  copy

CREATE OR REPLACE VIEW V_VIEW1(ID, NAME, SEX) AS SELECT ID, NAME, SEX  FROM learningt_employee;

(2) ALTER 命令

[sql]  view plain  copy

ALTER VIEW  V_VIEW1(ID, NAME) AS SELECT ID, NAME  FROM learningt_employee;

SELECT  FROM learningv_view1

6、更新视图

在MySQL中,更新视图是指通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)表中的数据。因为视图是一个虚拟表,其中没有数据,所以通过视图更新时,都是转换到基本表来更新。

更新视图时,只能更新权限范围内的数据。超出了范围,就不能更新。

更新前:

更新后:

[sql]  view plain  copy

UPDATE V_VIEW2 SET POS='高级工程师' WHERE NAME='天天'

对应 的真实表上的数据也发生改变 了

[sql]  view plain  copy

SELECT  FROM learningt_employee_detail WHERE t_employee_detailID=3

不可更新的视图:

某些视图是可更新的。也就是说,可以在诸如UPDATE、DELETE或INSERT等语句中使用它们,以更新基表的内容。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。还有一些特定的其他结构,这类结构会使得视图不可更新。更具体地讲,如果视图包含下述结构中的任何一种,那么它就是不可更新的:

· 聚合函数(SUM(), MIN(), MAX(), COUNT()等)。

· DISTINCT

· GROUP BY

· HAVING

· UNION或UNION ALL

· 位于选择列表中的子查询

· Join

· FROM子句中的不可更新视图

· WHERE子句中的子查询,引用FROM子句中的表。

· 仅引用文字值(在该情况下,没有要更新的基本表)。

· ALGORITHM = TEMPTABLE(使用临时表总会使视图成为不可更新的)。

注意

视图中虽然可以更新数据,但是有很多的限制。一般情况下,最好将视图作为查询数据的虚拟表,而不要通过视图更新数据。因为,使用视图更新数据时,如果没有全面考虑在视图中更新数据的限制,就可能会造成数据更新失败。

CASCADED和LOCAL能不能决定视图是否能更新?

WITH[CASCADED|LOCAL] CHECK OPTION能不能决定视图是否能更新?这两个参数的基本定义如下:

LOCAL参数表示更新视图时只要满足该视图本身定义的条件即可。

CASCADED参数表示更新视图时需要满足所有相关视图和表的条件。没有指明时,该参数为默认值。

With check option的用法:

(with check option对于没有where条件的视图不起作用的)

[sql]  view plain  copy

CREATE VIEW V_VIEW3(ID, NAME,SEX,AGE,DEPARTMENT,SALARY, HOME, MARRY, HOBBY) AS SELECT ID, NAME, SEX,AGE,DEPARTMENT,SALARY,HOME,MARRY,HOBBY FROM learningt_employee WHERE DEPARTMENT='人事部' WITH LOCAL CHECK OPTION;

表示只限定插入部门为人事部的人。

然后插入一条:

[sql]  view plain  copy

INSERT INTO learningV_VIEW3(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'会会会会','女',20,'人事部','4500','广东','否','网球');

看下结果:

[sql]  view plain  copy

SELECT  FROM learningV_VIEW3

同时看真实表中的数据:

再来插入一条:

[sql]  view plain  copy

INSERT INTO learningV_VIEW3(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) VALUES(NULL,'qqqqvasvas','女',20,'研发部','4500','上海','否','网球');

结果显示插入失败

对于with check option用法,总结如下:

通过有with check option选项的视图 *** 作基表(只是面对单表,对连接多表的视图正在寻找答案),有以下结论: 插入后的数据,通过视图能够查询出来就符合WITH CHECK OPTION 否则就不符合;

首先视图只 *** 作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来 *** 作。

1对于update,有with check option,要保证update后,数据要被视图查询出来

2对于delete,有无with check option都一样

4对于insert,有with check option,要保证insert后,数据要被视图查询出来

对于没有where 子句的视图,使用with check option是多余的

7、删除视图

[sql]  view plain  copy

DROP VIEW IF EXISTS 视图名

以上就是关于数据库问题求助全部的内容,包括:数据库问题求助、如何从phpmyadmin里面批量替换内容 mysql、数据库管理到底难不难,IT大佬们分享下经验等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9520851.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存