MySQL notes: Difference between revisions

From I Will Fear No Evil
Jump to navigation Jump to search
Line 64: Line 64:
</pre>
</pre>
====Group and sorts ====
====Group and sorts ====
Just a simple example of grouping by some column along with a column rename to something more "pretty" and then returning in descending order
<pre>
<pre>
mysql> select eventSeverity, count(*) as count from history group by eventSeverity order by eventSeverity DESC;
mysql> select eventSeverity, count(*) as count from history group by eventSeverity order by eventSeverity DESC;

Revision as of 10:36, 28 December 2023

Notes for working with MySQL

I am deliberately using a VERY old version of MySQL. 99% of the logic and commands will "just work" against other database types, and still give good performance. I feel this is a better solution instead of going for max performance that uses version or database specific enhancements. Likely later versions of the software will be done against updated databases looking more at performance. However right now, I want this to work on whatever people have available and not require heavy machines for monitoring.

My current priority list:

  • works on MySQL out of the box and can be used against PSQL easily (untested)
  • accurate
  • reasonably fast
  • can be added to easily by non-developers


Table Join logic

Basic table join for update from one table to another with where clause

UPDATE tableA a
  JOIN tableB b
    ON a.a_id = b.a_id
  JOIN tableC c
    ON b.b_id = c.b_id
   SET b.val = a.val+c.val
 WHERE a.val > 10
   AND c.val > 10;

Another way

UPDATE T1, T2,
[INNER JOIN | LEFT JOIN] T1 ON T1.C1 = T2.C1
SET T1.C2 = T2.C2, 
    T2.C3 = expr
WHERE condition

Full Text search

SELECT 
	productName 
FROM 
	products 
WHERE 
	MATCH(productName) 
    AGAINST('1992' WITH QUERY EXPANSION);

Simple JOIN

Also called an INNER JOIN clause using the event database on backup01 This assumes that there will ALWAYS be a match between the two tables. If there is not, then no rows returned.

 SELECT d.hostname,d.address,p.Properties FROM Device d JOIN DeviceProperties p on p.DeviceId=d.id  WHERE d.id=14 \G
*************************** 1. row ***************************
  hostname: nas01.iwillfearnoevil.com
   address: 192.168.15.125
Properties: {"snmpEnable":"true","snmpVersions":["2","1","3"],"snmpVersion":"2","snmpPort":161,"snmpTries":2,"snmpMonitorTimeout":1000000,"snmpV3SecurityName":"123Fake","snmpV3Hash":"456StillFake","snmpV3Password":"789Fake","snmpCommunities":["public","private","foobar"],"snmpCommunity":"public","snmpInterfaceIgnore":"lo vmnet[0-9]","snmpFilesystemIgnoreType":"romram virtualMemory loop","snmpfilesystemIgnoreMatch":"\/snap \/blah\/lxd rando\/foobar","snmpMaxOidPerRequest":"40","winUser":"admin administrator","winPassword":"password password123","winDomain":"DC:\\Domain","winEventLogSeverity":"2","winEventLogMonitor":"False","winWmiMonitorIgnore":"True","nrpeMonitorTimeout":"20","nmapDiscoverPortArgs":"-p 1-10024 -sT --open -oG -","nmapUpdatePortList":"False","nrpeCommandPath":"\/usr\/local\/bin\/nrpe","nmapCommandPath":"\/usr\/bin","sshPort":"22","sshKeyBase64":"LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcEFJQkFBS0NBUUVBdHRON05jVmtl","sshUser":"failSafeUser","sshPassword":"notAGoodIdea","sshPassowrdEncrypted":"stillNotAGreatIdea","pingMonitorIgnore":"False","comments":"","links":"https:\/\/linux.org"}
1 row in set (0.00 sec)

LEFT Join:

This makes no assumption on the second table, just that there will be a match in the first one.

SELECT d.hostname,d.address,p.Properties FROM Device d LEFT JOIN DeviceProperties p on p.DeviceId=d.id  WHERE d.id=26 \G
*************************** 1. row ***************************
  hostname: pipeload.com
   address: 172.92.156.161
Properties: NULL
1 row in set (0.00 sec)

Group and sorts

Just a simple example of grouping by some column along with a column rename to something more "pretty" and then returning in descending order

mysql> select eventSeverity, count(*) as count from history group by eventSeverity order by eventSeverity DESC;
+---------------+-------+
| eventSeverity | count |
+---------------+-------+
|             5 | 27170 |
|             4 |  8376 |
|             3 | 19299 |
|             2 |  1496 |
|             1 |  1995 |
|             0 |    13 |
+---------------+-------+
6 rows in set (0.19 sec)