我需要将旧数据库迁移到新数据库。不幸的是,编写旧数据库的人使用带有逗号分隔外键的字段创建了一个 n,n 关系。
我想编写一个 mysql 查询(可能使用 insert into ... select)来拆分那些以逗号分隔的外键,以便我可以构建一个表,其中每一行都是一个外键。
这可能吗?
最佳答案
在纯 SQL 中执行此操作并不简单。使用您选择的编程语言依次检索每条记录并根据逗号分隔字段插入多对多连接表记录将是最简单的方法。以下伪代码建议了一种您可能会使用的方法:
for each (id, csv_foreign_keys) in source_rows do
foreign_keys = split ',', csv_foreign_keys
for each fk in foreign_keys do
insert (id, fk) into many-to-many link table
完成此操作后,可以删除包含逗号分隔外键的现有列。
关于MySQL CSV 行到多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5041537/
这可能是个愚蠢的问题。但是,我是一个新手......你怎么能在交互式rubyshell中有多行代码?好像你只能有一条长线。按回车键运行代码。无论如何我可以在不运行代码的情况下跳到下一行吗?再次抱歉,如果这是一个愚蠢的问题。谢谢。 最佳答案 这是一个例子:2.1.2:053>a=1=>12.1.2:054>b=2=>22.1.2:055>a+b=>32.1.2:056>ifa>b#Thecode‘if..."startsthedefinitionoftheconditionalstatement.2.1.2:057?>puts"f
所以...SublimeText具有折叠方法的内置功能,但是一旦方法声明跨越多行,它就会失去这种能力。有谁知道插件或使它工作的方法吗?具体来说,我在使用ruby时遇到了这个问题(我的团队遵守关于行长度的严格风格指南),但语言应该无关紧要。 最佳答案 无需单击出现在函数定义第一行旁边的装订线中的向下箭头,您需要做的就是将光标放在函数的一个缩进行上(不是缩进的函数参数,而是在函数定义本身)并使用CtrlShift[键绑定(bind)(在OSX上使用⌘Alt[)折叠函数及其参数。使用CtrlShift](⌘Alt]在OSX上)展开,或
我正在使用dotenv.ARubygemtoloadenvironmentvariablesfrom.env.我的.env文件中是否可以包含多行变量?例如SOMETHING_CERTIFICATE="-----BEGINCERTIFICATE-----JSDFALDAFSSKLABVCXZLV2314IH4IHDFG9AYDF9DSSDF82QWEIWFHDSSD8SADF0=-----ENDCERTIFICATE-----"^上面的内容只会在中间那一行抛出一个错误,就好像它不是字符串的一部分,我正在尝试创建一个格式不正确的变量。 最佳答案
问题总结我想尝试使用Ruby来完成我在Python中所做的事情。在Python中它有r"""syntaxtosupportrawstrings,这很好,因为它允许将原始字符串与代码内联,并以更自然的方式连接它们,而无需特殊缩进。在Ruby中,当使用原始字符串时,必须使用其次是EOT在单独的行中,这会破坏代码布局。你可能会问,为什么不使用Ruby的%q{}?嗯,因为%q{}与Python的r"""相比有局限性因为它不会转义多个\\\并且只处理单个\.我正在动态生成Latex代码并写入一个文件,该文件稍后用pdflatex编译。Latex代码包含类似\\\的内容在许多地方。如果我使用Rub
我正在使用场景表(multilinesteparguments)使用内置的.diff来使用cucumber检查来自屏幕的一些数据!CucumberAST表上的方法。我想检查内容是否与正则表达式匹配。Scenario:OneThenthetableappearsas:|One|Two|Three||/\d+/|/\d+/|/\d+/|实际的表格看起来像|One|Two|Three||123|456|789|这个场景翻译成“只要有几个数字,我不在乎”失败的示例步骤实现:Then/^thetableappearsas:$/do|expected_table|actual_table=[['O
我的应用程序中有许多多行ActiveRelation查询方法,我不确定编写这些方法的最惯用方式。看看这个例子:defpostal_code_ids_within(miles)nearby_postal_codes=PostalCode.where("latitude>:min_latandlatitude:min_lonandlongitude我觉得有点不对劲。从中返回ActiveRelation对象的block似乎是惯用的,但我还没有看到这种方法。什么是标准? 最佳答案 根据Brian的建议,这更易读并且效果很好。scope:ne
我有一个多行字符串的空白问题。我在生成一些SQL的代码中有类似的内容。defgenerate_sql但是我的SQL缩进全乱了,这是我不想要的。"UPDATEpage\nSETview_count=10;\n"我能做到defgenerate_sql输出的正是我想要的"UPDATEpage\nSETview_count=10;\n"但是我的代码缩进全乱了,我真的不想要这样。关于如何最好地实现我所追求的目标有什么建议吗? 最佳答案 Ruby2.3.0使用squigglyheredoc很好地解决了这个问题.请注意示例之间波浪号/连字符的区别
是否有更好的方法来格式化此测试以使其更具可读性?expect{within'.foo'doclick_link'Delete'end}.tochange{Foo.count}.by1期望do...end有效,但更丑陋... 最佳答案 也许是这样的?expected=expectdowithin'.foo'doclick_link'Delete'endendexpected.tochange{Foo.count}.by1不是很漂亮,但减少了一些线路噪音。 关于ruby-on-rails-如
出于某种原因,我找不到任何提及如何执行此操作的教程...那么,如何从文件中读取前n行?我想出了:whileFile.open('file.txt')andcount但它不起作用,而且对我来说也不是很好。出于好奇,我试过类似的东西:File.open('file.txt').10.timesdo|f|但这也没有真正起作用。那么,有没有一种简单的方法可以只读取前n行而不必加载整个文件?非常感谢! 最佳答案 这是一个单行解决方案:lines=File.foreach('file.txt').first(10)我担心它可能不会及时关闭文件(
如何在Ruby中正确地编写多行算术?以前,我尝试过类似y的方法,然后我意识到该代码有问题。由于我的方程很长,我需要编写多行算术。a=5b=5x=(a+b)/2putsx#5,asexpectedy=(a+b)/2putsy#2,whathappened? 最佳答案 Ruby解析器会假定一条语句已经结束,如果它看起来像是在行尾结束的话。要防止这种情况发生,您可以将算术运算符放在新行之前,如下所示:a=1b=2c=a+b你会得到你期望的结果。 关于ruby-用Ruby编写多行算术,我们在St