今天有一个需求是迁移tag的数据,之前写的存储过程到现在都忘记了,从新再写一个,并在这里纪录一下,防止自己下次还忘记 首先是修改一下Mysql的配置 大家可以看下 这是我们老大的测试结果 SET GLOBAL max_allowed_packet=1024*1024*1024;SET GLOBAL key_buf
今天有一个需求是迁移tag的数据,之前写的存储过程到现在都忘记了,从新再写一个,并在这里纪录一下,防止自己下次还忘记
首先是修改一下Mysql的配置
大家可以看下
这是我们老大的测试结果
<code>SET GLOBAL max_allowed_packet=1024*1024*1024; SET GLOBAL key_buffer_size=1024*1024*1024; SET GLOBAL tmp_table_size = 512*1024*1024; SET SESSION myisam_sort_buffer_size = 512*1024*1024; SET SESSION read_buffer_size = 128*1024*1024; SET GLOBAL myisam_max_sort_file_size = 100*1024*1024*1024;</code>
下面选择数据库
<code>use db_database;</code>
如果有存储过程,先删除存储过程,(官方的中文翻译叫存储程序,感觉诡异)
<code>drop procedure 存储过程名称;</code>
好了,下面重头戏,把delimiter 改成 // 为开始和结束,并创建存储过程
<code>delimiter // CREATE PROCEDURE 存储过程的名称(); BEGIN</code>
好了下面我们来定义变量,这个大家都能看懂吧!
<code>DECLARE rid INT; DECLARE rtags VARCHAR(225); DECLARE lasttime datetime; DECLARE firsttime datetime; DECLARE done, duplicate, expcount INT DEFAULT 0;</code>
下面这个比较特殊,是定义游标(或者叫指针,但是官网上面叫光标),这个需求要获取id,来操作后面得数据
<code>DECLARE cur CURSOR FOR SELECT id FROM 表名 ORDER BY id ASC;</code>
然后设置各种状态下的设置的变量的值
Mysql各种状态都在这里了
当sql错误状态是02000的时候 done这个变量为1
<code>DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;</code>
同上
<code>DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' SET duplicate = 1;</code>
设置变量
<code>SET lasttime = now(); SET firsttime = now();</code>
下面我们来遍历游标
打开游标
<code>OPEN cur;</code>
遍历
<code>REPEAT FETCH cur INTO rid; if not done then SET duplicate = 0; UPDATE 另一张表 SET keywords = 数据是啥 WHERE id = rid;</code>
好了,上面就是写你的sql,下面是100条的时候,打印出来执行时间和条数
<code>SET expcount = expcount + 1; IF expcount % 100 = 0 then SELECT expcount,now() - lasttime; SET lasttime = now(); END IF;</code>
直到没有数据,遍历结束
<code>end if; UNTIL done END REPEAT;</code>
关闭游标
<code>CLOSE cur;</code>
最后结束存储过程
<code>END; // delimiter ;</code>
以上就是做的存储过程的数据迁移的部分,这个写的比较简单,不过以后有复杂的可以直接修改修改就可以用了!

Mysqldiffersfromothersqldialectsyntaxforlimit, auto-increment, stringcomparison, subqueries, andperformanceanalysis.1) mySqlusSlimit, whilesqlserverestopandoracleusesusesrownum.2)

Pemisahan MySQL meningkatkan prestasi dan memudahkan penyelenggaraan. 1) Bahagikan jadual besar ke dalam kepingan kecil dengan kriteria tertentu (seperti julat tarikh), 2) secara fizikal membahagikan data ke dalam fail bebas, 3) MystQL boleh memberi tumpuan kepada partisi yang berkaitan apabila pertanyaan, 4) Pengoptimal pertanyaan boleh melangkau partisi yang tidak berkaitan, 5) Memilih strategi partisi yang tepat dan mengekalkannya secara tetap adalah kunci.

Bagaimana untuk memberikan dan membatalkan keizinan di MySQL? 1. Gunakan pernyataan geran untuk memberikan kebenaran, seperti GrantallPrivileGeSondatabase_name.to'username'@'host '; 2. Gunakan pernyataan membatalkan untuk membatalkan kebenaran, seperti RevokeAllPrivileGeSondatabase_name.from'username'@'host 'untuk memastikan komunikasi tepat pada masanya perubahan kebenaran.

InnoDB sesuai untuk aplikasi yang memerlukan sokongan transaksi dan kesesuaian yang tinggi, sementara myisam sesuai untuk aplikasi yang memerlukan lebih banyak bacaan dan kurang menulis. 1.InnoDB menyokong kunci transaksi dan peringkat bank, sesuai untuk sistem e-dagang dan perbankan. 2.Myisam menyediakan bacaan dan pengindeksan yang cepat, sesuai untuk sistem pengurusan blog dan kandungan.

Terdapat empat jenis utama dalam MySQL: innerjoin, leftjoin, rightjoin dan fullouterjoin. 1.InnerJoin Mengembalikan semua baris dalam dua jadual yang memenuhi syarat gabungan. 2.LeftJoin Mengembalikan semua baris di meja kiri, walaupun tidak ada baris yang sepadan di meja yang betul. 3. Rightjoin bertentangan dengan leftjoin dan mengembalikan semua baris di meja kanan. 4.FullouterJoin Mengembalikan semua baris dalam dua jadual yang memenuhi atau tidak memenuhi syarat gabungan.

MysqloffersvariousstorageEngines, eachSuitedfordifferentusecases: 1) innodbisidealforapplicationsNeedingacidcomplianceandhighconcurrency, supportingtransactionsandforeignkeys.2) myisamisbestforread-heavyworkloads, lacktransactive.2)

Kelemahan keselamatan biasa dalam MySQL termasuk suntikan SQL, kata laluan yang lemah, konfigurasi kebenaran yang tidak betul, dan perisian yang tidak dimulakan. 1. Suntikan SQL boleh dicegah dengan menggunakan pernyataan pra -proses. 2. Kata laluan yang lemah boleh dielakkan dengan secara paksa menggunakan strategi kata laluan yang kuat. 3. 4. Perisian yang tidak ditetapkan boleh ditampal dengan kerap memeriksa dan mengemas kini versi MySQL.

Mengenal pasti pertanyaan perlahan dalam MySQL boleh dicapai dengan membolehkan log pertanyaan perlahan dan menetapkan ambang. 1. Dayakan log pertanyaan perlahan dan tetapkan ambang. 2. Lihat dan menganalisis fail log pertanyaan perlahan, dan gunakan alat seperti mysqldumpslow atau pt-que-digest untuk analisis mendalam. 3. Mengoptimumkan pertanyaan perlahan dapat dicapai melalui pengoptimuman indeks, penulisan pertanyaan dan mengelakkan penggunaan pilih*.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Dreamweaver Mac版
Alat pembangunan web visual

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna
