<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Convert Update SQL statement to proc sql in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689884#M209765</link>
    <description>I did try it, but SAS gives out error for the TOP 1 statement, so I'm still stuck.</description>
    <pubDate>Thu, 08 Oct 2020 07:39:38 GMT</pubDate>
    <dc:creator>Ja5ya</dc:creator>
    <dc:date>2020-10-08T07:39:38Z</dc:date>
    <item>
      <title>Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689433#M209597</link>
      <description>&lt;P&gt;Say I have 2 tables as following. What would be equivalent proc sql code to the update statement be?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;create&amp;nbsp;table&amp;nbsp;#City (CityId varchar(20), [Name] varchar(20), Period varchar(20))&lt;/P&gt;&lt;P&gt;create&amp;nbsp;table&amp;nbsp;#Assets (AssetId varchar(20), [Name] varchar(20))&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#City values (1, 'Asset1', null)&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#City values (2, 'Asset2', null)&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#City values (3, 'Asset3', null)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (1, 'Asset1')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (2, 'Asset1')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (3, 'Asset1')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (4, 'Asset2')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (5, 'Asset2')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (6, 'Asset3')&lt;/P&gt;&lt;P&gt;insert&amp;nbsp;into&amp;nbsp;#Assets values (7, 'Asset3')&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;select&amp;nbsp;* from&amp;nbsp;#City&lt;/P&gt;&lt;P&gt;select&amp;nbsp;* from&amp;nbsp;#Assets&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;update&amp;nbsp;#City&lt;/P&gt;&lt;P&gt;set&amp;nbsp;Period&amp;nbsp;= (&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; select&amp;nbsp;top 1&amp;nbsp;a.AssetID&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; from&amp;nbsp;#Assets a&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; where&amp;nbsp;#City.Name = a.Name&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; order&amp;nbsp;by&amp;nbsp;a.AssetId asc)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;select&amp;nbsp;* from&amp;nbsp;#City&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;drop&amp;nbsp;table&amp;nbsp;#City&lt;/P&gt;&lt;P&gt;drop&amp;nbsp;table&amp;nbsp;#Assets&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you!&lt;/P&gt;</description>
      <pubDate>Wed, 07 Oct 2020 04:21:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689433#M209597</guid>
      <dc:creator>Ja5ya</dc:creator>
      <dc:date>2020-10-07T04:21:15Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689478#M209614</link>
      <description>&lt;P&gt;If you remove the&amp;nbsp;&lt;SPAN&gt;octothorpes and add semicolons, you should be fairly close to valid SAS SQL code.&lt;/SPAN&gt;&lt;/P&gt;</description>
      <pubDate>Wed, 07 Oct 2020 08:46:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689478#M209614</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2020-10-07T08:46:45Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689870#M209760</link>
      <description>&lt;P&gt;Hello?&lt;/P&gt;</description>
      <pubDate>Thu, 08 Oct 2020 05:19:14 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689870#M209760</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2020-10-08T05:19:14Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689884#M209765</link>
      <description>I did try it, but SAS gives out error for the TOP 1 statement, so I'm still stuck.</description>
      <pubDate>Thu, 08 Oct 2020 07:39:38 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689884#M209765</guid>
      <dc:creator>Ja5ya</dc:creator>
      <dc:date>2020-10-08T07:39:38Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689886#M209767</link>
      <description>Show us&lt;BR /&gt;</description>
      <pubDate>Thu, 08 Oct 2020 07:48:13 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689886#M209767</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2020-10-08T07:48:13Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689903#M209777</link>
      <description>&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;update City&lt;BR /&gt;set Period = (&lt;BR /&gt;select top 1 a.AssetID&lt;BR /&gt;ERROR 22-322: Syntax error, expecting one of the following: a quoted string, !, !!, &amp;amp;, (, *, **, +, ',', -, '.', /, &amp;lt;, &amp;lt;=, &amp;lt;&amp;gt;, =,&lt;BR /&gt;&amp;gt;, &amp;gt;=, ?, AND, AS, BETWEEN, CONTAINS, EQ, EQT, FORMAT, FROM, GE, GET, GT, GTT, IN, INFORMAT, INTO, IS, LABEL, LE,&lt;BR /&gt;LEN, LENGTH, LET, LIKE, LT, LTT, NE, NET, NOT, NOTIN, OR, TRANSCODE, ^, ^=, |, ||, ~, ~=.&lt;BR /&gt;&lt;BR /&gt;ERROR 200-322: The symbol is not recognized and will be ignored.&lt;BR /&gt;from Assets a&lt;BR /&gt;where City.Name = a.Name&lt;BR /&gt;order by a.AssetId asc);&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;</description>
      <pubDate>Thu, 08 Oct 2020 09:00:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/689903#M209777</guid>
      <dc:creator>Ja5ya</dc:creator>
      <dc:date>2020-10-08T09:00:01Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/690192#M209942</link>
      <description>&lt;P&gt;This is not valid ANSI SQL. Only SQL Server accepts this syntax.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Try something like this:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data T; 
  set SASHELP .CLASS;
proc sql;
  update T
  set AGE = (
    select max(WEIGHT)
    from SASHELP.CLASS 
    where T.AGE = CLASS.AGE 
  ) where T.AGE&amp;gt;14;
&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 08 Oct 2020 20:44:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/690192#M209942</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2020-10-08T20:44:09Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/690269#M209994</link>
      <description>It didn't work as I am getting only one distinct value of weight when max function is used while top 1 produces multiple distinct values</description>
      <pubDate>Fri, 09 Oct 2020 04:55:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/690269#M209994</guid>
      <dc:creator>Ja5ya</dc:creator>
      <dc:date>2020-10-09T04:55:52Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/692051#M210731</link>
      <description>&lt;P&gt;Change the code accordingly then. My code was an example of a valid query,&amp;nbsp;I am unsure what you are after.&lt;/P&gt;
&lt;P&gt;Just explaining that different SQL engines use different syntaxes, and you have to adapt your code accordingly.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;EM&gt;&amp;gt;&amp;nbsp;&amp;nbsp;top 1 produces multiple distinct values&lt;/EM&gt;&lt;/P&gt;
&lt;P&gt;Does it?&lt;STRONG&gt;&amp;nbsp;Select top 1&lt;/STRONG&gt; limits the number of returned records to one.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 16 Oct 2020 06:24:44 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/692051#M210731</guid>
      <dc:creator>ChrisNZ</dc:creator>
      <dc:date>2020-10-16T06:24:44Z</dc:date>
    </item>
    <item>
      <title>Re: Convert Update SQL statement to proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/692060#M210736</link>
      <description>Sure, I'll keep trying. The result I got from max wasn't what I was expecting so it didn't work out.</description>
      <pubDate>Fri, 16 Oct 2020 07:23:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-Update-SQL-statement-to-proc-sql/m-p/692060#M210736</guid>
      <dc:creator>Ja5ya</dc:creator>
      <dc:date>2020-10-16T07:23:48Z</dc:date>
    </item>
  </channel>
</rss>

