PoshCode Archive  Hex Artifact Content

Artifact d4afa2a2a4a818fabceef0784bf630f8053b68c9f01b46206aa18660dd1324fb:

  • File Run-Query.ps1 — part of check-in [e6605bffdf] at 2018-06-10 12:56:16 on branch trunk — Runs a FullTextSqlQuery against your local MOSS farm; useful as a quick(!) search query test workbench. (user: unknown size: 1240)

0000: 23 20 65 6e 63 6f 64 69 6e 67 3a 20 61 73 63 69  # encoding: asci
0010: 69 0d 0a 23 20 61 70 69 3a 20 70 6f 77 65 72 73  i..# api: powers
0020: 68 65 6c 6c 0d 0a 23 20 74 69 74 6c 65 3a 20 0d  hell..# title: .
0030: 0a 23 20 64 65 73 63 72 69 70 74 69 6f 6e 3a 20  .# description: 
0040: 52 75 6e 73 20 61 20 46 75 6c 6c 54 65 78 74 53  Runs a FullTextS
0050: 71 6c 51 75 65 72 79 20 61 67 61 69 6e 73 74 20  qlQuery against 
0060: 79 6f 75 72 20 6c 6f 63 61 6c 20 4d 4f 53 53 20  your local MOSS 
0070: 66 61 72 6d 3b 20 75 73 65 66 75 6c 20 61 73 20  farm; useful as 
0080: 61 20 71 75 69 63 6b 28 21 29 20 73 65 61 72 63  a quick(!) searc
0090: 68 20 71 75 65 72 79 20 74 65 73 74 20 77 6f 72  h query test wor
00a0: 6b 62 65 6e 63 68 2e 0d 0a 23 20 76 65 72 73 69  kbench...# versi
00b0: 6f 6e 3a 20 30 2e 31 0d 0a 23 20 74 79 70 65 3a  on: 0.1..# type:
00c0: 20 66 75 6e 63 74 69 6f 6e 0d 0a 23 20 6c 69 63   function..# lic
00d0: 65 6e 73 65 3a 20 43 43 30 0d 0a 23 20 66 75 6e  ense: CC0..# fun
00e0: 63 74 69 6f 6e 3a 20 52 75 6e 2d 51 75 65 72 79  ction: Run-Query
00f0: 0d 0a 23 20 78 2d 70 6f 73 68 63 6f 64 65 2d 69  ..# x-poshcode-i
0100: 64 3a 20 31 30 31 33 0d 0a 23 20 78 2d 61 72 63  d: 1013..# x-arc
0110: 68 69 76 65 64 3a 20 32 30 30 39 2d 30 34 2d 31  hived: 2009-04-1
0120: 36 54 30 31 3a 32 39 3a 32 31 0d 0a 23 0d 0a 23  6T01:29:21..#..#
0130: 0d 0a 66 75 6e 63 74 69 6f 6e 20 52 75 6e 2d 51  ..function Run-Q
0140: 75 65 72 79 28 24 73 69 74 65 55 72 6c 2c 20 24  uery($siteUrl, $
0150: 71 75 65 72 79 54 65 78 74 29 0d 0a 7b 0d 0a 09  queryText)..{...
0160: 5b 72 65 66 6c 65 63 74 69 6f 6e 2e 61 73 73 65  [reflection.asse
0170: 6d 62 6c 79 5d 3a 3a 6c 6f 61 64 77 69 74 68 70  mbly]::loadwithp
0180: 61 72 74 69 61 6c 6e 61 6d 65 28 22 6d 69 63 72  artialname("micr
0190: 6f 73 6f 66 74 2e 73 68 61 72 65 50 4f 69 6e 74  osoft.sharePOint
01a0: 22 29 20 7c 20 6f 75 74 2d 6e 75 6c 6c 0d 0a 09  ") | out-null...
01b0: 5b 72 65 66 6c 65 63 74 69 6f 6e 2e 61 73 73 65  [reflection.asse
01c0: 6d 62 6c 79 5d 3a 3a 6c 6f 61 64 77 69 74 68 70  mbly]::loadwithp
01d0: 61 72 74 69 61 6c 6e 61 6d 65 28 22 6d 69 63 72  artialname("micr
01e0: 6f 73 6f 66 74 2e 6f 66 66 69 63 65 2e 73 65 72  osoft.office.ser
01f0: 76 65 72 22 29 20 7c 20 6f 75 74 2d 6e 75 6c 6c  ver") | out-null
0200: 0d 0a 09 5b 72 65 66 6c 65 63 74 69 6f 6e 2e 61  ...[reflection.a
0210: 73 73 65 6d 62 6c 79 5d 3a 3a 6c 6f 61 64 77 69  ssembly]::loadwi
0220: 74 68 70 61 72 74 69 61 6c 6e 61 6d 65 28 22 6d  thpartialname("m
0230: 69 63 72 6f 73 6f 66 74 2e 6f 66 66 69 63 65 2e  icrosoft.office.
0240: 73 65 72 76 65 72 2e 73 65 61 72 63 68 22 29 20  server.search") 
0250: 7c 20 6f 75 74 2d 6e 75 6c 6c 0d 0a 09 24 73 20  | out-null...$s 
0260: 3d 20 5b 6d 69 63 72 6f 73 6f 66 74 2e 73 68 61  = [microsoft.sha
0270: 72 65 70 6f 69 6e 74 2e 73 70 73 69 74 65 5d 24  repoint.spsite]$
0280: 73 69 74 65 55 72 6c 0d 0a 09 24 71 20 3d 20 6e  siteUrl...$q = n
0290: 65 77 2d 6f 62 6a 65 63 74 20 6d 69 63 72 6f 73  ew-object micros
02a0: 6f 66 74 2e 6f 66 66 69 63 65 2e 73 65 72 76 65  oft.office.serve
02b0: 72 2e 73 65 61 72 63 68 2e 71 75 65 72 79 2e 66  r.search.query.f
02c0: 75 6c 6c 74 65 78 74 73 71 6c 71 75 65 72 79 20  ulltextsqlquery 
02d0: 2d 61 72 67 20 24 73 0d 0a 09 24 71 2e 71 75 65  -arg $s...$q.que
02e0: 72 79 74 65 78 74 20 3d 20 24 71 75 65 72 79 54  rytext = $queryT
02f0: 65 78 74 0d 0a 09 24 71 2e 52 6f 77 4c 69 6d 69  ext...$q.RowLimi
0300: 74 20 3d 20 31 30 30 0d 0a 09 24 71 2e 52 65 73  t = 100...$q.Res
0310: 75 6c 74 54 79 70 65 73 20 3d 20 22 52 65 6c 65  ultTypes = "Rele
0320: 76 61 6e 74 52 65 73 75 6c 74 73 22 0d 0a 09 24  vantResults"...$
0330: 64 74 20 3d 20 24 71 2e 45 78 65 63 75 74 65 28  dt = $q.Execute(
0340: 29 0d 0a 09 24 72 20 3d 20 24 64 74 5b 22 52 65  )...$r = $dt["Re
0350: 6c 65 76 61 6e 74 52 65 73 75 6c 74 73 22 5d 0d  levantResults"].
0360: 0a 0d 0a 09 24 6f 75 74 70 75 74 20 3d 20 40 28  ....$output = @(
0370: 29 0d 0a 09 0d 0a 09 77 68 69 6c 65 20 28 24 72  )......while ($r
0380: 2e 52 65 61 64 28 29 29 20 7b 0d 0a 09 09 24 6f  .Read()) {....$o
0390: 20 3d 20 6e 65 77 2d 6f 62 6a 65 63 74 20 50 53   = new-object PS
03a0: 4f 62 6a 65 63 74 0d 0a 0d 0a 09 09 30 2e 2e 28  Object......0..(
03b0: 24 72 2e 46 69 65 6c 64 43 6f 75 6e 74 2d 31 29  $r.FieldCount-1)
03c0: 20 7c 20 66 6f 72 65 61 63 68 20 7b 0d 0a 09 09   | foreach {....
03d0: 09 61 64 64 2d 6d 65 6d 62 65 72 20 2d 69 6e 70  .add-member -inp
03e0: 75 74 4f 62 6a 65 63 74 20 24 6f 20 2d 6d 65 6d  utObject $o -mem
03f0: 62 65 72 54 79 70 65 20 22 4e 6f 74 65 50 72 6f  berType "NotePro
0400: 70 65 72 74 79 22 20 2d 6e 61 6d 65 20 24 72 2e  perty" -name $r.
0410: 47 65 74 4e 61 6d 65 28 24 5f 29 20 2d 76 61 6c  GetName($_) -val
0420: 75 65 20 24 72 5b 24 5f 5d 2e 54 6f 53 74 72 69  ue $r[$_].ToStri
0430: 6e 67 28 29 0d 0a 09 09 7d 0d 0a 09 09 0d 0a 09  ng()....}.......
0440: 09 0d 0a 09 09 24 6f 75 74 70 75 74 20 2b 3d 20  .....$output += 
0450: 24 6f 0d 0a 09 7d 0d 0a 09 0d 0a 09 72 65 74 75  $o...}......retu
0460: 72 6e 20 24 6f 75 74 70 75 74 0d 0a 7d 0d 0a 0d  rn $output..}...
0470: 0a 23 53 61 6d 70 6c 65 20 75 73 61 67 65 3a 0d  .#Sample usage:.
0480: 0a 23 52 75 6e 2d 51 75 65 72 79 20 2d 73 69 74  .#Run-Query -sit
0490: 65 55 72 6c 20 22 68 74 74 70 3a 2f 2f 64 65 76  eUrl "http://dev
04a0: 2f 22 20 2d 71 75 65 72 79 54 65 78 74 20 22 53  /" -queryText "S
04b0: 45 4c 45 43 54 20 50 72 65 66 65 72 72 65 64 4e  ELECT PreferredN
04c0: 61 6d 65 2c 20 57 6f 72 6b 50 68 6f 6e 65 20 46  ame, WorkPhone F
04d0: 52 4f 4d 20 53 22 0d 0a                          ROM S"..