- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的数据库中有一个未规范化的表,名称为 details
结构和示例数据如下(为图像道歉,只是认为它会更容易理解):
我的挑战是拆分列 - assignee、inventor 和 ipcsubclass
使用分隔符 |
到新表 {detail_inv
和 inventors
}、{detail_asg
和 assignees
} 以及 {detail_ipc
和 ipcsubclasses
}。
在所有这三种情况下,表架构都是相似的。例如,inventors 表上的列 - id
和 name
以及 detail_inv 表上的列 - detail_id
和 inventor_id
。每行必须只有一个名称,所有名称在 inventors 表中都是唯一的,ids 在 detail_inv 表中保持关系。
我为发明者尝试了以下代码的存储过程-我为 3 列制作了 3 个过程:(
drop procedure if exists normalise_details;
delimiter #
create procedure normalise_details()
proc_main:begin
declare v_cursor_done int unsigned default 0;
declare v_post_id int unsigned;
declare v_tags varchar(2048);
declare v_keyword varchar(50);
declare v_keyword_id mediumint unsigned;
declare v_tags_done int unsigned;
declare v_tags_idx int unsigned;
declare v_cursor cursor for select id, inventor from details order by id;
declare continue handler for not found set v_cursor_done = 1;
set autocommit = 0;
open v_cursor;
repeat
fetch v_cursor into v_post_id, v_tags;
set v_tags_done = 0;
set v_tags_idx = 1;
while not v_tags_done do
set v_keyword = substring(v_tags, v_tags_idx,
if(locate('|', v_tags, v_tags_idx) > 0,
locate('|', v_tags, v_tags_idx) - v_tags_idx,
length(v_tags)));
if length(v_keyword) > 0 then
set v_tags_idx = v_tags_idx + length(v_keyword) + 1;
set v_keyword = trim(v_keyword);
insert into inventors (name) values (v_keyword);
select id into v_keyword_id from inventors where name = v_keyword;
insert into details_inv (inventor_id, detail_id) values (v_keyword_id, v_post_id);
else
set v_tags_done = 1;
end if;
end while;
until v_cursor_done end repeat;
close v_cursor;
commit;
end proc_main #
delimiter ;
当我在一些随机测试数据上尝试这个时,它工作正常。当我在实际的 table 上这样做时,效果不佳。仅插入部分数据。 SQL 不会抛出任何错误(除了某些时候:“#1172 - 结果由多行组成”或“inventor_id 列不能为空”)
我尝试修改代码 MySQL - Insert comma separated list into normalized tables via stored procedure满足我的需求,但我失败了。
请帮助我,我的数据库表已经变得一团糟,大约有 500,000 行,这让我很难在每个项目(最近的项目有 ~200,000 行)上展开和管理巨大的数组。
最佳答案
查看 RolandoMySQLDBA 对此 dba.stackexchange question 的帖子我对触发存储过程的最初保留意见得到了证实。但是,如果您确定在任何给定时间只有几行 被用户输入更改,那么应该可以组合一个快速执行的程序。
但是,如果有许多用户并行工作,他们可能仍然会互相锁定。我不知道这是否真的会发生,因为存储过程不会更改 details
表中的任何内容。如有必要,您可以查看 this page的想法。
编辑:触发
我只是将我之前帖子的 SQLfiddle 扩展到这个 SQLfiddle with trigger ,包含以下内容:
CREATE TRIGGER normdet AFTER INSERT ON detail FOR EACH ROW
BEGIN
DECLARE n int; DECLARE word VARCHAR(64)
;SET n=cntparts(NEW.inventor)
;WHILE n>0 DO
SET word=part(new.inventor,n)
;IF NOT EXISTS (SELECT * FROM inv WHERE invname=word) THEN
INSERT INTO inv (invname) VALUES (word)
;END IF
;INSERT INTO det2inv (didid,diiid)
SELECT NEW.id,invid FROM inv WHERE invname=word
;SET n=n-1
;END WHILE
-- and similar loops for assignee and cls ...
;END;
我还定义了另一个函数
CREATE FUNCTION cntparts (var varchar(1024)) RETURNS int
RETURN 1+LENGTH(var)-LENGTH(REPLACE(var,'|',''));
计算给定 varchar
中的单词。这也可用于创建循环,而不是我在第一篇文章中为基本转换固定的 UNION
构造。
触发器现在负责处理所有新的 INSERT
。仍然需要编写一个类似的触发器来为 UPDATE
执行相同的操作。这应该不会太难...
在我的 SQLfiddle 中,我在 detail
触发器定义中插入了另一行。结果由两个比较 SELECT 语句列出,请参阅 fiddle .
回复最后一条评论:
好吧,正如我在原始答案中所建议的那样,您应该首先导入所有数据(无需安装任何触发器!!!!)然后仔细研究细节
-table 与 SELECT/UNION
语句。在你这样做之前,你应该通过使用
SELECT MAX(cntparts(inventor)) invcnt,
MAX(cntparts(assignee)) asscnt,
MAX(cntparts(ipsubclass)) clscnt
FROM detail
然后您可以调整每列所需的 SELECT/UNION
语句的数量。然后填写链接表,如 SQLfiddle 中所示。
也许整个过程需要一段时间,但您可以安全地处理一个接一个的表(首先是实际的属性表,然后是关联的链接表)。
之后您可以激活您的触发器,它应该然后只对单独添加的行起作用。
关于MySQL:拆分列(带分隔符)并插入新表的存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18573727/
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
我对 Angular 还很陌生。我有一个由一些数据填充的列表项: {{content.Company}} {{content.Town}}, {{content.P
我正在尝试从 SwiftUI 中的 List 中删除“行”分隔符(在 SwiftUI 中称为分隔符)。 我浏览了 List 文档,但我没能找到它的修饰符。 如有任何帮助,我们将不胜感激。 最佳答案 i
我有一个带有 4 个按钮的网格...1 行 4 列。我正在寻找一种方法将左侧的两个按钮与右侧的两个按钮进行视觉分组。我一直在寻找一种使用分隔符执行此操作的方法,但它似乎与 Grid 一起玩得不好,更喜
我对 R 语言相当陌生。所以我有这个包含以下内容的向量: > head(sampleVector) [1] "| txt01 | 100 | 200 | 123.456
我正在尝试连接两列中的值,当我使用 =CONCAT(A2,",",B2) 时,它将连接两列并获得正确的结果 (P0810,P1)。但我正在寻找的是这样的东西(“P0810”,“P1”)。我尝试了 =C
我在这里创建了一个简单的演示。在 amount 字段编辑时,我想显示 , 分隔符?目前,它仅在不处于编辑模式时显示 ,。知道如何实现这一目标吗? DEMO IN DOJO var data = [{
这里是java菜鸟... 这让我抓狂,因为我知道这很简单,但我已经为此工作了 30 分钟...... 这是来自代码战斗: 对于参数 = ["Code", "Fight", "On", "!"] 且分隔
基于这个pywin32基础script如何向托盘菜单 menu_options 添加分隔符? 我还可以让菜单在左键单击时弹出,而不仅仅是右键单击吗? 最佳答案 将 notify 函数(从 URL 中的
我正在使用这段代码: StringTokenizer tokenizer=new StringTokenizer(line, "::"); 拆分以下字符串: hi my name is visghal
- Dropbox login fix - Updated iris viewer * other aspects are to be improved + fix crash on viewing
我试图在每个菜单组之间显示一个分隔线。我已经尝试过为每个组提供一个唯一的 ID,但这没有用。我找到了一些其他解决方案,但它们看起来有点奇怪,比如创建高度为 1dp 的 LinearLayout。 这是
我想为 CONCAT_WS() 选择一个与字段值不冲突的分隔符例如,如果我选择“,”,则字段值可能包含带有“,”的字符串我想选择一个与字段值不冲突的分隔符:( 最佳答案 来自here : CONCAT
我想知道 Sphinx 引擎是否可以使用任何定界符(如普通 MySQL 中的逗号和句点)。我的问题来自于一种冲动,根本不使用它们,而是逃避它们,或者至少在使用 FULLTEXT 搜索执行 MATCH
我正在尝试使用 svg 或纯 css3 制作 header 分隔符,如下所示: preview from design 在 header 中我有标准的 bootstrap 4 轮播
我在使用 CSS 分隔符时遇到了一些难题。看看:http://jsfiddle.net/fVxC6/1/ .div-line { border-bottom: 1px solid #f0f0f
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 7 年前。 编辑问题以包含 desired behavior, a specific probl
嘿,我正在尝试使用 getline 读取以下行 (15,0,1,#) (2,11,2,.) (3,20,0,S) 我希望能够将整数提取为 int,将字符提取为 char,但我不知道如何只提取它们。 最
我有 2 列,每边 float 一列,我想使用 1px 宽度的线分隔符,从最长列的顶部到底部。 我宁愿远离 TABLE 布局,而且我不知道哪一个将是最长的列,或者它会有多长。 我怎么能只用 css 做
我是一名优秀的程序员,十分优秀!