pg_conn 0.38.2 → 0.39.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 27da5832145c359fa1472604184f836add4fabceb458dee4b609c05b6eec5196
4
- data.tar.gz: 109029c0961d83cb35710d2f716a31412eb1fcf68d55b05b1d1d6dc26af6b8d3
3
+ metadata.gz: ace2859257bedbbdeb816bfb04d9d7e23d686942c328e0d521568b6f4fc57e90
4
+ data.tar.gz: b803feaaaa619668cf00f57d2c5ffd072f04a149e144eafb061b85d4bf4cfad4
5
5
  SHA512:
6
- metadata.gz: f787e6859f348afd97657c15f6fce1c75ab8e1dc0eeb04ef703879b6b50c493246eb71ec1690b8eb3f2c3f98fefd0b204d7ddde5e6e5d9fe76de5f46c21ff964
7
- data.tar.gz: 15968312f5b7f5b0835ebd694484deb6ac84c4dd51c57b99d710b72b08d51d154c040f61acef2751037a7f1d0967f3d7ccdcf271d29ce5cbd4432055e61dc003
6
+ metadata.gz: b2b913861f23ed8db39f8d521571bb054c3ed9ca1526b800c5f4982f9b4a9f285cc60b17dc59194b2df7cc2147019faaef7b838a4e10d4e8659941adb6fddde9
7
+ data.tar.gz: aac27bc4b8e7881ded4fdfe350a98be3de919052b9b5fcbca0d6767573dd9592d4922e3b2da968860b146d451b05bb96937e7344941d58048a104c5b8bda9081
@@ -152,7 +152,7 @@ module PgConn
152
152
  end
153
153
  end
154
154
 
155
- # Set current serial value for the table
155
+ # Set current serial value for the table. The sequence is marked unused if value is nil
156
156
  def set_serial(schema, table, value)
157
157
  uid = "#{schema}.#{table}"
158
158
  seq = sequence(schema, table) or raise ArgumentError, "Table #{uid} does not have a sequence"
@@ -1,3 +1,3 @@
1
1
  module PgConn
2
- VERSION = "0.38.2"
2
+ VERSION = "0.39.0"
3
3
  end
data/lib/pg_conn.rb CHANGED
@@ -739,6 +739,14 @@ module PgConn
739
739
  h
740
740
  end
741
741
 
742
+ # TODO
743
+ # structset
744
+ # recordset
745
+ # structmap
746
+ # recormap
747
+ # multistruct
748
+ # multirecord
749
+
742
750
  # Return the value of calling the given postgres function. It dynamically
743
751
  # detects the structure of the result and return a value or an array of
744
752
  # values if the result contained only one column (like #value or #values),
@@ -780,9 +788,9 @@ module PgConn
780
788
 
781
789
  # :call-seq:
782
790
  # insert(table, record|records)
783
- # insert(table, fields, record|records|tuples)
791
+ # insert(table, fields, record|records|tuples|values)
784
792
  # insert(schema, table, record|records)
785
- # insert(schema, table, fields, record|records|tuples)
793
+ # insert(schema, table, fields, record|records|tuples|values)
786
794
  #
787
795
  # Insert record(s) in table and return id(s)
788
796
  #
@@ -821,7 +829,8 @@ module PgConn
821
829
  fields ||= data.first.keys
822
830
  tuples = data.map { |record| fields.map { |field| record[field] } }
823
831
  else
824
- raise ArgumentError
832
+ fields.size == 1 or raise ArgumentError, "Illegal number of fields, expected exactly one"
833
+ tuples = data.map { |e| [e] }
825
834
  end
826
835
  elsif data.is_a?(Hash)
827
836
  method = upsert ? :value? : :value # The pg_conn method when only one record is inserted
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: pg_conn
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.38.2
4
+ version: 0.39.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Claus Rasmussen