mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-31 10:30:33 +03:00 
			
		
		
		
	This isn't fully tested as yet, in particular I'm not sure that the "foo--unpackaged--1.0.sql" scripts are OK. But it's time to get some buildfarm cycles on it. sepgsql is not converted to an extension, mainly because it seems to require a very nonstandard installation process. Dimitri Fontaine and Tom Lane
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| CREATE EXTENSION pg_trgm;
 | |
| 
 | |
| select show_trgm('');
 | |
| select show_trgm('(*&^$@%@');
 | |
| select show_trgm('a b c');
 | |
| select show_trgm(' a b c ');
 | |
| select show_trgm('aA bB cC');
 | |
| select show_trgm(' aA bB cC ');
 | |
| select show_trgm('a b C0*%^');
 | |
| 
 | |
| select similarity('wow','WOWa ');
 | |
| select similarity('wow',' WOW ');
 | |
| 
 | |
| CREATE TABLE test_trgm(t text);
 | |
| 
 | |
| \copy test_trgm from 'data/trgm.data
 | |
| 
 | |
| select t,similarity(t,'qwertyu0988') as sml from test_trgm where t % 'qwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu0988') as sml from test_trgm where t % 'gwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu1988') as sml from test_trgm where t % 'gwertyu1988' order by sml desc, t;
 | |
| select t <-> 'q0987wertyu0988', t from test_trgm order by t <-> 'q0987wertyu0988' limit 2;
 | |
| 
 | |
| create index trgm_idx on test_trgm using gist (t gist_trgm_ops);
 | |
| set enable_seqscan=off;
 | |
| 
 | |
| select t,similarity(t,'qwertyu0988') as sml from test_trgm where t % 'qwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu0988') as sml from test_trgm where t % 'gwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu1988') as sml from test_trgm where t % 'gwertyu1988' order by sml desc, t;
 | |
| explain (costs off)
 | |
| select t <-> 'q0987wertyu0988', t from test_trgm order by t <-> 'q0987wertyu0988' limit 2;
 | |
| select t <-> 'q0987wertyu0988', t from test_trgm order by t <-> 'q0987wertyu0988' limit 2;
 | |
| 
 | |
| drop index trgm_idx;
 | |
| create index trgm_idx on test_trgm using gin (t gin_trgm_ops);
 | |
| set enable_seqscan=off;
 | |
| 
 | |
| select t,similarity(t,'qwertyu0988') as sml from test_trgm where t % 'qwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu0988') as sml from test_trgm where t % 'gwertyu0988' order by sml desc, t;
 | |
| select t,similarity(t,'gwertyu1988') as sml from test_trgm where t % 'gwertyu1988' order by sml desc, t;
 | |
| 
 | |
| create table test2(t text);
 | |
| insert into test2 values ('abcdef');
 | |
| insert into test2 values ('quark');
 | |
| create index test2_idx_gin on test2 using gin (t gin_trgm_ops);
 | |
| set enable_seqscan=off;
 | |
| explain (costs off)
 | |
|   select * from test2 where t like '%BCD%';
 | |
| explain (costs off)
 | |
|   select * from test2 where t ilike '%BCD%';
 | |
| select * from test2 where t like '%BCD%';
 | |
| select * from test2 where t like '%bcd%';
 | |
| select * from test2 where t ilike '%BCD%';
 | |
| select * from test2 where t ilike 'qua%';
 | |
| drop index test2_idx_gin;
 | |
| create index test2_idx_gist on test2 using gist (t gist_trgm_ops);
 | |
| set enable_seqscan=off;
 | |
| explain (costs off)
 | |
|   select * from test2 where t like '%BCD%';
 | |
| explain (costs off)
 | |
|   select * from test2 where t ilike '%BCD%';
 | |
| select * from test2 where t like '%BCD%';
 | |
| select * from test2 where t like '%bcd%';
 | |
| select * from test2 where t ilike '%BCD%';
 | |
| select * from test2 where t ilike 'qua%';
 |