我有一个表,它被许多其他表上的外键引用。在我的程序中,如果我想删除其中一行,我需要首先搜索依赖项并将它们呈现给用户——“这个对象依赖于表y中的x,表q中的z,等等”。我还预计,随着时间的推移,具有该表外键的表的数量将显著增加
信息模式数据库是搜索所有依赖项的好方法吗?我试图查询它以检索所有表的列表,这些表都有外键,然后迭代结果并从每个表中选择外键值与用户试图删除的值匹配的所有条目。我的问题如下:
SELECT * FROM `KEY_COLUMN_USAGE` kcu
LEFT JOIN TAB
我有一个包含两列的序列表,分别是name和value,还有一个存储过程,用于递增名称提供的值
DROP PROCEDURE IF EXISTS p_generate_sequence;
delimiter |
CREATE PROCEDURE p_generate_sequence (name VARCHAR(30))
BEGIN
START TRANSACTION;
-- Variable "name" equal to column "name", how to refere
mysql>update tablename set fieldname='C200900674'其中fieldname-
‘C200900673’
错误1062(23000):键1的重复条目“C200900674-2008-0-1”
对此有何想法或建议?有人不小心用减号而不是等号进行了更新。它显然试图更改所有小于该值的记录?尽管它是字母数字的,而且非常不完整。最重要的是,在收到错误之前,大量的记录都被更新了,而且根本没有任何反馈。没有什么像“查询确定,X行受影响(0.00秒)”那样,所以我们不
是否有一个开源的替代MaxMind GeoIP Country/City,我可以用于MySQL?并且可以在
All advertising materials and documentation mentioning features or use of
this database must display the following acknowledgment:
"This product includes GeoLite data created by MaxMind, available
WindowsXP。Ruby 1.9.2。安装了导轨。安装了MySQL。当我尝试运行gem install mysql2(或bundle install)时,我收到错误:
C:\ruby\cred2>gem install mysql2
Building native extensions. This could take a while...
ERROR: Error installing mysql2:
ERROR: Failed to build gem nati
如何使用MySQL将空值插入INT列?
是否可能?如果列不为非空(可空)
您只需在INSERT语句中输入NULL而不是值。如果列具有notnull约束,则不可能;但除此之外,这很好:
INSERT INTO MyTable(MyIntColumn) VALUES(NULL);
该列是否允许null
似乎有效。刚刚使用phpMyAdmin进行了测试,列的类型为int,允许空值:
INSERT INTO `database`.`table` (`column`) VALUES (NULL);
2
在过去的两天里,我一直在问关于Mysql中排名查询的问题。到目前为止,我已经为
查询表中的所有行,并按其排名排序
仅查询一行及其秩
这是我昨晚提问的链接
正如您可能注意到的,btilly的查询速度非常快
这里是一个仅获取一行及其排名的查询,我是基于btilly的查询进行的
set @points = -1;
set @num = 0;
select * from (
SELECT id
, points
, @num := if(@points = points, @num, @
标签: Mysql
View
federatedfederated-tablefederated-storage-engine
如何创建放置在远程服务器上的联邦on视图?我正在使用MySQL。是的,您可以在视图上创建一个联邦表
下面是一个简单的例子:
create table t_table (
id int not null auto_increment primary key
) engine = innodb;
create or replace view v_view as select * from t_table;
create table f_fed_table (
id int not null
)
好吧,我想我已经很接近我所需要的了,但我不确定有几件事:
TABLE messages
message_id
message_type
sender_id
timestamp
TABLE message_type
message_type_code (1, 2, 3)
name (global, company, personal)
TABLE message_to_user
message_id
receiver_id
status (read/unread)
目标:
能够向所有用
我想知道,如果我有一个200个字符的VARCHAR,并且我放了一个100个字符的字符串,它会使用200字节还是只使用字符串的实际大小?100个字符
这是varchar中的var(变量):您只存储您输入的内容(以及额外的2个字节以存储长度高达65535的内容)
如果是char(200),那么您将始终存储200个字符,并用100个空格填充
见文件:
VARCHAR意味着它是一个可变长度的字符,所以它只是
将占用必要的空间。但是如果你知道些什么
关于底层结构,限制VARCHAR可能是有意义的
达到某个
我提议的触发因素:
#START TRIGGER
delimiter //
DECLARE msg VARCHAR(255);
CREATE TRIGGER passStandard_check BEFORE INSERT ON Module
FOR EACH ROW
BEGIN
IF NEW.passStandard < 0 || NEW.passStandard > 1 THEN
set msg = concat('Trigger Error: Pass Standard:
我有一个主要对全文索引字段进行操作的查询
查询如下:
SELECT
MATCH (g.GameTitle) AGAINST ('quake ii') as Score,
g.*, p.id AS platformid,
p.alias AS PlatformAlias,
p. name,
p.icon
FROM
games as g,
platforms as p
WHERE
MATCH (g.GameTitle) AGAINST
我正在为一个在线图书馆搜索引擎工作,但我有点困在这里。在搜索标签时,或搜索(即带有“tag1”或“tag2”的书籍)工作正常,但和搜索给我带来了一些麻烦
我用于此目的的表(及其列)是:
books | book_id, other_info
tagmap | map_id, book_id, tag_id
tags | tag_id, tag_text
由于用户可以启用/禁用一系列其他搜索选项,因此该查询由PHP生成。搜索标记为“tag1”和“tag2”的书籍时,将生成以下查询:
SEL
我有一个数据库表:mydata
id content name
1 1 a
2 2 b
3 2 c
4 13 hhh
5 13 yyyy
6 7 wwww
7 13 iiii
8 7 nnnn
9 8 oooo
它将查看“内容”字段。如果“内容”中的相同值显示多次,则会显示出来
我想知道如何将数据从Hive移动到MySQL
我已经看到了如何将配置单元数据移动到AmazonDynamodB的示例,但没有看到像MySQL这样的RDBMS。下面是我在DynamoDB中看到的示例:
CREATE EXTERNAL TABLE tbl1 ( name string, location string )
STORED BY 'org.apache.hadoop.hive.dynamodb.DynamoDBStorageHandler'
TBLPROPERTIES ("dynamod
一年分为12个月。我们可以在四个星期内把一个月分解
在MySQL中,如何返回每月的一周?(示例:第一周:2个条目,第二周:5个条目,第三周:3个条目;第四周:8个条目)
使用Week和WeekOfYear无法获得所需的结果,因为函数返回的周数是YEAR,而不是month
FLOOR((DayOfMonth(dateCol)-1)/7)+1
我想明确指出,这可能不是划分数据的好方法-(请参阅注释),但这将使您尽可能接近数据。使用MySQL内置函数week查找一年的周数,然后减去当月第一天的周数
标签: Mysql
group-bygroup-concatmysql-select-db
我有一个select查询要构建,但无法使其正常工作。我希望更高级的MySQL开发人员能给我一些建议。
所以我的桌子是:
CREATE TABLE IF NOT EXISTS `gv` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`option_id` int(11) NOT NULL,
`group_id` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin
我有下面的MySQL表,如下图所示。该表被命名为示例_表:
该表包含已销售产品的列表、销售时间以及销售价格
现在,我尝试在表格上做一些“分析”,以确定用户输入的特定日期前5天的平均销售价格
我试图实现的输出如下。
我有部分查询,但这不是我所需要的。
SELECT product_name,time_value,AVG(selling_price) as 'Average Selling Price'
from example_table
where product_name='Samsung
我使用此MySQL查询创建存储过程:
Delimiter //;
Create Procedure addUser(
IN facebookId varchar(20),
IN name varchar(50),
In accessToken varchar(100),
in expires float)
Begin
Declare invitingUsers Table(Id varchar(20));
I
我想根据一个条件,通过一个SQL select查询动态添加另一个列hook\u name
例如,如果hook\u type=0,则表hook\u name的值应为OFFER,同样,对于hook\u type=1,hook\u name应显示“ACCEPT”
以下是结果的屏幕截图:
选择查询如下所示:
select hook_type, 'hook name' as hook_name,
count(*) as number_of_exchange_activities
from
我想知道如何在codeigniter选择中使用mysqlDATE\u ADD()
编辑:DATE\u ADD()和SELECT中的任何其他MySQL函数
这就是我所拥有的。还尝试将FALSE作为第二个参数
$this->db->select(" DATE_ADD( purchased_on , INTERVAL 1 YEAR) AS wrty_end");
结果是它将INTERVAL作为字段读取。当我尝试在phpmyadmin中运行它而不使用包含INTERVAL的倒勾时,它工作得很
mysql是否足够智能,如果自上次运行以来未对文件进行修改,则不会通过加载数据填充重新处理该文件?找不到关于此的文档。它将再次添加数据。这是我的经验
编辑:
我进一步研究了这一点,发现如下:
可以忽略具有重复键的行。因此,如果您的整个文件没有更改,那么实际上,它将被忽略
REPLACE和IGNORE关键字控制对在唯一键值上复制现有行的输入行的处理:
如果指定“替换”,则输入行将替换现有行。换句话说,主键或唯一索引值与现有行相同的行。参见第13.2.7节“替换语法”
如果指定“忽略”,将跳过与唯一
我有一个用户和特征表。像这样:
|用户名1 |特征A|
|用户名2 |特征B|
|用户名2 |特征A|
有几百种特征。我想做的是,当用户在表中输入任何特征时,建议第二个特征。我想创建一个表格,使用当前数据来确定任何具有特质a的人有%可能也具有特质B(或C或D…)的概率,因此该表格将如下所示:
|性状A |性状B |概率百分比|
|性状A |性状C |概率百分比|
例如,约翰喜欢苹果,我们知道喜欢苹果的人往往喜欢香蕉,所以我们建议约翰试试香蕉。请试试这个
注意trait=t1.trait和t1.t
我只能在桌子上选择
该表有一个名为inty的列,其值为0或1
我目前选择inty作为:
SELECT inty AS InternetApproved FROM Table1
是否有方法重新格式化SQL SELECT中的数据,以便如果值为0,则将其设置为否;如果值为1,则将其设置为是,以便在输出选择结果中显示
select case when inty = 0 then 'no' else 'yes' end as newcolname from table1;
SELECT IF(int
我的教科书对基数的定义如下:
关系的基数是它包含的元组数。相反,元组的数量称为关系的基数,并且随着元组的添加或删除而改变。高基数-多个元组,低基数-少数元组
Wikipedia文章对其进行了如下定义:
基数是指数据库表的特定列(属性)中包含的数据值的唯一性。基数越低,列中重复的元素越多。基数有三种类型:高基数、正常基数和低基数
它们可能都是对的,但我无法将这两个定义作为相关定义联系起来。请重新措辞 这两个定义都试图说基数是“行数”。区别在于比较是“在表中”还是“在特定列中”
数据库教科书中的版本
我需要使用Ansible备份服务器上的所有现有MySQL数据库
我知道这个模块。它一个接一个地获取我想要操作的数据库的名称,因此在使用该模块之前,我必须获得现有数据库的列表
有没有办法一次备份所有MySQL数据库,或者使用Ansible获取现有数据库的列表?MySQL\u db模块在引擎盖下使用mysqldump可执行文件,这反过来提供了一个--all databases开关,只是Ansible模块没有提供通过模块使用它的选项
我建议现在通过command模块使用mysqldump可执行文件,同
我从Oracle数据库中获取了.dmp导出文件。现在我想把这个文件导入MySQL工作台
我尝试使用管理菜单中的数据“导入/还原”链接。当我导入.dmp文件时,它显示导入已完成。但在模式中,它并没有显示那个数据库
我试图看看这个链接,但它没有给我任何适当的解决方案。还有其他导入方法吗?oracle dmp文件是专有的,不能导入到非oracle数据库中MySQL归oracle所有,这不是一个不合理的要求。
我一直在尝试用SQL编写一些代码,但它总是出现一个关于连接的语法错误,我不知道为什么
SELECT `COUNTRY$`.country_name, `PARTNER$`.partner_name, count(member_id)
FROM `Member$`
Left Join `COUNTRY$`
ON `MEMBER$`.country_id=`COUNTRY$`.country_id
lEFT jOIN `PARTNER$`
on `MEMBER$`.partner_ID = `
因此,我在MySQL 5.1上的tinyint(2)unsigned列中遇到了这个问题
上次我检查时,tinyintunsigned接受的最大值为255,参见
现在,当我尝试为所有条目更新此列时,添加一个随机生成的值,介于100和160之间,如下所示:
UPDATE composition SET range = range + (FLOOR(100 + RAND() * 60));
我收到一条智能消息,告诉我有一个超出范围的错误:
第1660行“范围”列的值超出范围
这怎么可能呢?只需验证现
我有一个企业模型:
name - VARCHAR 255
name - VARCHAR 255
Acandidate型号:
first_name - VARCHAR 255
last_name - VARCHAR 255
和类型型号:
name - VARCHAR 255
name - VARCHAR 255
每个企业都可以选择他们感兴趣的一种或多种类型。每个候选人都能做到这一点
我试图显示与当前登录的企业共享某些类型的所有候选资格的列表它们不需要完全相同的类型,只需共享其中一些类型即
我当前的查询列出了WordPress用户/用户元数据库中的一些信息,但该查询没有完成,速度变慢,几乎停止了操作,直到我停止该过程
有没有更有效的方法来执行此查询?我认为选择所有数据并将其放在另一个表中以便于报告会更好。然而,我并不擅长MYSQL,因此不确定最好的方法是什么
SELECT
u1.ID,
u1.user_login,
u1.user_email,
m1.meta_value AS Gender,
m2.meta_value AS Username,
m3.meta_valu
代码:-
街道\表的主名称、位置\列的名称
-我正在努力实现的目标
-将存储有字符串(某个地址)的列locality\u name的每一行与我将要插入的locality\u name进行比较……因此,如果可能存在重复项,应通知我
我是否应该使用“LIKE”而不是STRCMP…如果是,那么如何
执行后出现的错误
1064-触发用户地址检查的语法错误
在插入或更新到street_master之前
MySQL中没有创建或替换触发器的命令。放下触发器,然后重新创建它。请参阅。然后只需使用创建触发器。阅读
在我的MySQL数据库(5.X)中,我有一个存储所有其他表信息的表(下一个id等)。
可以这样更新此表吗?
在我的表“tables”中有一个字段“tableName”和“nextId”。我想做一些类似的事情:
UPDATE tables SET nextId = (SELECT MAX(id) FROM tables.tableName);
编辑:
我现在知道不可能动态确定表名。
但是,我可以为每一行做吗?我可以轻松地让所有查询自动生成。
这样的话:
UPDATE tables SET nex
因此,我正在修改数据库中的外键,这在很大程度上进展顺利。然而,我遇到了一个查询,它不能用于新的FK引用
我已经构建了一个快速的示例来显示表结构的骨架
基本上,我试图解决的查询是电缆,用于引用主表,但现在引用的是子表(内置于小提琴中)。但是,此查询也引用了区域表,我不确定如何保留该引用,因为电缆表不再引用主要表
有问题的查询如下所示:
SELECT
C.name,
M.name AS Origin,
M.area AS OriginArea
FROM cable C
INNER J
我有一个后处理应用程序,它需要向数百万记录表的每个条目添加三个值。该进程每15分钟运行一次,需要为此表的每行添加三个值。向该表中添加三列(更新)或创建一个带有外键的新表(插入)更好吗
编辑:
虽然这是一个更一般的问题,但根据请求:
CREATE TABLE `position` (
`idPosition` int(10) unsigned NOT NULL AUTO_INCREMENT,
`idRover` int(10) unsigned DEFAULT NULL,
`TimeHack` d
用户帐户的数据库结构(表中的字段)应该是什么。我想要的是当管理员创建一个新的用户帐户时,该帐户应该处于非活动状态,直到用户设置密码为止。
当管理员创建用户帐户时,它会创建一个url,并在用户打开该url时,将其注册的电子邮件Id发送给该用户,用户将看到一个设置密码的页面。当他设置密码时,用户帐户应该被激活。
下面是我的示例数据库结构
CREATE TABLE user_account (
user_id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
fst_
我想用t_三中的对应值更新t_on.f6,该值取决于连接。这个查询在mysql中运行得很好,但是我得到了
甲骨文中的错误
ORA-00971:缺少集合关键字
在MSSQL中
查询中出错:“t1”附近的语法不正确
对此我能做些什么呢?我永远记不起各个子句出现的顺序,但这是一个大致相同的顺序
update t_one t1
join t_two t2 on (t2.f1 = t1.f1)
join t_three t3 on (t1.f4 = t3.f4 and t2.f5 = t3.f5)
s
因此,基本上(如果标题不清楚),我有一个食谱数据库,其中包含下图中的表格
现在,有一件事困扰着我,例如,我在配方表中有一份煎蛋食谱和煎饼食谱,在配料表中有所需的配料,所以这里有一个问题-两种食谱都需要鸡蛋,但一份煎蛋可能需要4个鸡蛋(数据库中的数量实际上是以克为单位的,大约200克)煎饼可能需要3个鸡蛋(150克)
我怎样才能使以鸡蛋为原料的那一行对每种配方都有不同的值?多次添加鸡蛋并在配料表中为其设置不同的值将不起作用,因为它不会被标准化。我与一个名为QUANTITY的表建立了一个多对多关系,
我的理解是,query\u alloc\u block\u大小决定了查询缓存的块大小。在我的例子中,它是默认的8K
当我计算查询\u缓存\u大小/Qcache\u总数\u块时,我得到的数字范围为1-4K。为什么它们会随着时间的推移而改变?为什么它们在查询块大小时会有所不同
此外,查询缓存最小分辨率单位的默认值为4K。为什么会比查询、分配、块大小小?它不需要是查询、分配、块大小的倍数吗
很明显,我误解了一些非常基本的问题。嗯,我不能回答具体的问题
我对QC的看法是:如果您对正在运行查询的表进行了少
标签: Mysql
innodbamazon-aurora
我看到有很多人在写。我可以通过显示全局状态来查看计数,其中变量名称类似于'Created\u tmp\u disk\u tables'
我知道我可以更新max\u heap\u table\u size和tmp\u table\u size来帮助防止这种情况,但是如果不知道写入磁盘的表的大小,就很难知道要使用什么值
有人知道如何找到这个值吗?只要查看文档,并假设仅仅知道表的数量是不够的(查看创建的\u tmp\u表),该变量将为您提供存储这些表的目录的位置。降低温度应确保在磁盘上创建临时表,以便
目前我知道AWS RDS官方文档可以实现只读拷贝功能
例如:
RDS主库是生产库,主库有3个表(a、b、c),主库使用只读副本创建子库,然后只读副本升级到数据库实例,官方链接如下:
将读取副本升级到DB实例(我称之为新DB实例)后,如果我希望此新DB实例满足以下要求,将采取哪些步骤:
新数据库实例有5个表(a、b、c、d、e),其中a、b、c三个表与主库中三个表的数据一致(相当于这三个表是库的主只读副本),d、e两个表可以修改。当一个RDS实例是另一个RDS实例的读副本时:
复制副本随主机上
我要做百分比的列
我需要写:1.00,2.00,99.99,100..%
我怎么能用双面打印呢
现在我有:
Double(4,2)
但当我在列中写100时,我得到一个错误:
数值超出范围:列的1264超出范围值
double(4,2)表示总共有四位数字的双精度,其中两位位于小数点的右侧,这意味着在小数点左侧只有4-2=2位100小数点左侧有三位数字,因此存在错误。改为使用双精度(5,2)可以解决问题。查看答案(double和decimal的语法相同)或:
双[(M,D)]
M是总位数,D是小数
假设我有一个“源表”,其中包含一些行,在本例中为四行。现在,我想为源表中的每一行在“目标表”中插入新行
我目前的发言是:
SET @id = 1;
INSERT INTO target_table (id, value)
VALUES (@id, 1),
(@id, 2),
(@id, 3),
(@id, 4);
但是我想做一些像这样的事情
SET @id = 1;
myResultSet = SELECT value FROM source_tabl
我正在将一个模式从Postgres转换为MySQL,但显然缺少一个内置函数来聚合由(子)查询返回的一组结果,类似于Postgres的string_agg()。具体来说,假设一个表t有3行:
COL
"x"
"y"
"z"
在Postgres中,从t中选择字符串_agg(col,,')将返回一个单行结果,其中所有col值都与指定的分隔符连接,即字符串x,y,z。如何在MySQL中实现这一点?用于连接由分隔符字符串分隔的不同行值(默认值为逗号(,)
扩展版本可以是:
SELECT GROUP_CO
我想设计一个web应用程序来跟踪组织成员的财务状况。某些功能非常类似于。我使用MWE数据库图定义我的需求:
“财务”表:每个用户将有一个个人财务帐户,我使用以下三个红色表:
“SharedExpense”表:每个用户可以在许多“共享费用组”中与其他用户共享费用。对于每组,我使用以下三个蓝色表格:
(请注意每个用户如何定义其共享金额以及自己的共享费用类别。UserShare表使用复合主键。)
问题:我必须将用户与他们的3个个人“财务”表和3N“共享支出”表关联起来(其中N是用户所属的“共享
我在搜索我的表以查找具有精确字符数的单词时遇到困难
我试图在一个包含8个字符的电影列表中找到特定的电影标题,并尝试使用语法中的“like”部分,但最终得到错误消息或完整的电影列表。我是一个新的MySQL,所以试图得到一个基础。
我知道它可能已关闭,但我正在尝试:
select title from film_list where varchar = '8';
我想你不能在where序列中使用数据类型,但我不确定应该在哪里包含它
我也尝试过:
select title from film_lis
我在寻找我的数据中的错误;在表中的不同列中。我使用UNION语句一次运行多个查询,查找表中的错误。表中找到的所有错误都放在发现错误的第一个查询的列名下的一列中。有没有一种方法可以拆分列,使UNION语句中单独查询发现的每个错误也作为单独的列/实体显示
这是我正在使用的代码:
SELECT DISTINCT
[1001account]
FROM
[Cris_Ocean_tmp].[dbo].[NiiStressTest2018_v2_PUBLISHED_201812_CC_0326]
WHER
如何运行查询将数据库中的价格列从文本转换为数字(BIGINT)?是否可以仅使用SQL查询进行此类处理
Price
————-
2 millions 5 hundreds thousands
52 thousands
3 hundreds 25 thousands
10 millions 30 thousands
更新
就像你们所评论的,我想这项任务最好用其他语言而不是SQL来完成 你能做到吗?当然可以,但你真的不应该。下面是一个可能的示例(缩写):
SELECT CAST(CONCAT(
我有一个带有列名、关系客户和关系类别的表“staff”
id | Name | client_id | category
1 | Test 1 | 0 | 22
2 | Test 2 | 2 | 22
3 | Test 3 | 3 | 22
4 | Test 4 | 5 | 22
5 | Test 11 | 0 | 25
6 | Test 22 | 2 | 25
7 | T
我想知道是否有可能在MySQL 5.7的CASE语句中避免第二次相等的计算
CASE
WHEN char_length(cat.DESCRIPTION) > 0 THEN char_length(cat.DESCRIPTION)
ELSE ''
END AS D_LENGTH
第二个字符长度对我来说似乎是多余的,可能会降低查询性能。有什么方法可以改进这一点吗?由于您似乎希望在列的字符长度为零时显示空字符串,您可以尝试在此处使用修剪技巧:
选择修剪(字符长度(类别描述)中的前导
上一页 1 2 ...
4 5 6 7 8 9 10 ...
下一页 最后一页 共 6985 页