mysql_framework 1.0.1 → 1.1.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 +4 -4
- data/lib/mysql_framework/sql_query.rb +13 -0
- data/lib/mysql_framework/version.rb +1 -1
- data/spec/lib/mysql_framework/sql_query_spec.rb +10 -0
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: c803b7020c3d65742c29d1e354945c61cf1c097fccd13e6ec25861410ea2d5af
|
4
|
+
data.tar.gz: b0a3ca6bf7946c34cce87aa797ffb6d91a5bf65e42cdb0092d990fc6f42f327d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 576b1afe0fc7469168de50cb94a705efe00e565f7057fc72e3a41a44bd7a8cdff9187fcd1d0ec22298e56c4c5452eaa3eb3b62c858225d16eef6e77512fe915d
|
7
|
+
data.tar.gz: c90070d20e9cf952dc0d395833f35dfa4d330756023242d0d997ccd3216ad9a1eca23f535cba65efcb4e7e665d851b9e6237ecfe882ab09473b53d922f6e9978
|
@@ -76,6 +76,19 @@ module MysqlFramework
|
|
76
76
|
self
|
77
77
|
end
|
78
78
|
|
79
|
+
# This method is called to specify the columns to bulk upsert.
|
80
|
+
def bulk_upsert(columns)
|
81
|
+
@sql += 'ON DUPLICATE KEY UPDATE '
|
82
|
+
|
83
|
+
columns.each do |column|
|
84
|
+
@sql += "#{column} = VALUES(#{column}), "
|
85
|
+
end
|
86
|
+
|
87
|
+
@sql = @sql.chomp(', ')
|
88
|
+
|
89
|
+
self
|
90
|
+
end
|
91
|
+
|
79
92
|
# This method is called to specify the columns to update.
|
80
93
|
def set(values)
|
81
94
|
@sql += ' SET '
|
@@ -139,6 +139,16 @@ describe MysqlFramework::SqlQuery do
|
|
139
139
|
end
|
140
140
|
end
|
141
141
|
|
142
|
+
describe '#bulk_upsert' do
|
143
|
+
it 'sets the sql for the upsert statement' do
|
144
|
+
columns = %w(column_1 column_2)
|
145
|
+
|
146
|
+
subject.bulk_upsert(columns)
|
147
|
+
|
148
|
+
expect(subject.sql).to eq('ON DUPLICATE KEY UPDATE column_1 = VALUES(column_1), column_2 = VALUES(column_2)')
|
149
|
+
end
|
150
|
+
end
|
151
|
+
|
142
152
|
describe '#set' do
|
143
153
|
it 'sets the sql for the set statement' do
|
144
154
|
subject.set(name: 'mysql_framework', author: 'sage', created_at: '2016-06-28 10:00:00')
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: mysql_framework
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0
|
4
|
+
version: 1.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Sage
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2019-06-
|
11
|
+
date: 2019-06-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -150,7 +150,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
150
150
|
- !ruby/object:Gem::Version
|
151
151
|
version: '0'
|
152
152
|
requirements: []
|
153
|
-
rubygems_version: 3.0.
|
153
|
+
rubygems_version: 3.0.4
|
154
154
|
signing_key:
|
155
155
|
specification_version: 4
|
156
156
|
summary: A lightweight framework to provide managers for working with MySQL.
|